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DEVICES, METHODS AND A SYSTEM FOR IMPLEMENTING A 
MEDIA CONTENT DELIVERY AND PLAYBACK SCHEME 

REFERENCE TO COMPACT DISC APPENDIX 

A compact disc appendix including a computer program listing is filed 
herewith. The compact disc appendix includes the computer source code of a 
preferred embodiment of the present invention. Other embodiments of the present 
invention may be implemented using other computer code, using dedicated 
electronic hardware, using a combination of these, or otherwise. The contents of 
the compact disc appendix are incorporated herein in their entirety and are to be 
considered to be part of the disclosure of this specification, the files, dates of 
creation and size in bytes of each file are listed in Figures 1 1 - 23. 

BACKGROUND OF THE INVENTION 

i 

1. FIELD OF THE INVENTION 

The present invention relates to the distribution of media content. In 
particular, the present invention relates to devices, methods and a system for 
implementing a media content delivery and playback scheme. The present 
invention provides for the delivery of media content asynchronously via a 
communication channel to facilitate playback of the media content through a 
remote device. 

2. DESCRIPTION OF RELATED ART 

A conventional system for the delivery of media content may utilize media 
streaming, a technique whereby media content is delivered to a remote device in 
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small segments. Each of the segments is stored in a buffer until there are a 
sufficient number of segments stored within the buffer to provide the user of the 
remote device with the opportunity to playback the media content in what appears 
to the user to be in a continuous stream. However, if there are problems with 
delivering the media content over the network, the playback of the media content 
may be disrupted A conventional system is disclosed in U.S. Patent No. 
5,917,835 to Progressive Networks, Inc., which is incorporated herein by 
reference. This system has been marketed under the trade name "REAL 
AUDIO"®. 

SUMMARY OF THE INVENTION 

The principal advantage of the present invention is the provision of 
devices, methods and a system for implementing a media content delivery and 
playback scheme. - 

According to a first embodiment of the present invention, a device is 
provided including a processor that controls asynchronous delivery of media 
content over a communication channel to facilitate playback of the media content 
through a remote device. The playback of the media content is enabled at a 
predetermined time after the delivery of the media content. 

According to one aspect of the first embodiment, the device may deliver 
the media content. According to another aspect of the first embodiment, the 
communication channel includes a satellite communication channel. According 
to yet another aspect of the first embodiment, the device may be a server 
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computer. According to still another aspect of the first embodiment, the delivery 
of the media content may be controlled in accordance with a digital rights 
management scheme. According to yet another aspect of the first embodiment, 
the remote device may include a client computer. According to yet another aspect 
of the first embodiment, the remote device may be a portable device. In addition, 
the portable device may be a wireless device, such as a cellular phone. 

According to a second embodiment of the present invention, a device is 
provided including a processor that controls asynchronous delivery of media 
content over a communication channel including a satellite system to facilitate 
playback of the media content through a remote device. The playback of the 
media content is enabled at a predetermined time after the delivery of the media 

content 

) 

According to a third embodiment of the present invention, a device is 
provided including a processor executing software instructions including a 
software module. The software module includes a software delivery module that 
controls asynchronous delivery of media content over a communication channel 
to facilitate playback of the media content through a remote device. The playback 
of the media content is enabled at a first predetermined time after the delivery of 
the media content. 

According to one aspect of the third embodiment, the device may deliver 
the media content Acp^ding to another aspect of the present invention, the 
device may be a server computer. According to another aspect of the present 
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invention, the device also includes a memory portion that stores at least a portion 
of the software module. 

According to still another aspect of the third embodiment, the software 
delivery module generates indicator data for the remote device that provide an 
indication of a second predetermined time when the media content will be 
delivered to the remote device. The device delivers the media content to the 
remote device at the second predetermined time. According to still yet another 
aspect of the third embodiment, the remote device initiates a session with the 
software delivery module not prior to the second predetermined time. According 
to yet another aspect of the present invention, the remote device initiates the 
session by making a request for a connection with the device. The device may 
establish the connection in response to the request. The device then provides the 
remote device with an indication that a user of the remote device is entitled to the 
media content The remote device then accepts the media content for delivery 
unless the remote device already has the media content 

According to yet another aspect of the third embodiment, the software 
module may also include a software recovery module, which provides control 
information to the software delivery module to enable the automatic delivery of 
disrupted data without delivering data that has already been successfully delivered 
to the remote device. 

According to still yet another aspect of the third embodiment, the software 
module may also include a software database interface module that processes 
requests to retrieve information from a database including media content 
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information related to the media content. The software database interface module 
may receive a request for the information from the remote device, submit the 
request to the database, receive the information from the database, and send the 
information to the remote device. The software database interface module may 

> also receive a request for the information from the software delivery module, 

submit the request to the database, receive the information, and send the 
information to the software delivery module to facilitate the delivery of the media 
content to the remote device. 

According to yet another aspect of the third embodiment, the media 

) content information may include at least an identifier identifying a media category 

with which the media content is associated. The media category may be a 
segment of an episode, an episode, a series, or a package with which the media 
content is associated. The package may be defined in accordance with user 
statistical information related to media usage by a user employing the remote 

5 device. The software delivery module may control the delivery of the media 

content based on user statistical information concerning media usage by a user 
employing the remote device. 

According to yet another aspect of the third embodiment, the software 
delivery module may control the delivery of the media content in segments, each 

0 having a size which depends on the user statistical information. 

According to still yet another aspect of the third embodiment, the software 
module may also include a software user interface module that processes requests 
for the information from a user of the remote device and submits the requests for 
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the information to the software database interface module for retrieval from the 
database. The software user interface module may include a graphical user 
interface. The graphical user interface may be implemented via a web site. 

According to yet another aspect of the third embodiment, the software 
module may also include a software storage module that facilitates the storage of 
media content in a media content repository by a content provider. 

According to still yet anbther aspect of the third embodiment, the software 
database interface module may receive a request for the information from the 
software storage module, submit the request to the database, receive the 
information from the database, and send the information to the software storage 
module to facilitate storage of the media content in the media content repository. 

According to yet another aspect of the third embodiment, the software 
module may also include a software content provider interface module that 
processes requests for the information from a content provider and submits the 
requests for the information to the software database interface module for 
retrieval from tfie database. The software content provider interface module may 
include a graphical user interface. The graphical user interface may be 
implemented via a web site. 

According to a fourth embodiment of the present invention, a device is 
provided that includes a processor that controls playback of media content 
delivered asynchronously over a communication channel by a remote device. The 
playback of the media content is enabled at a predetermined time after the 
delivery of the media content 
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According to one aspect of the fourth embodiment, the media content is 
not detectable by a user of the device until the predetermined time. 

According to another aspect of the fourth embodiment, the processor may 
control the playback of media content via a display. 

According to yet another aspect of the fourth embodiment, the device may 
include a display and the processor may control the playback of media content via 
the display. 

According to still yet another aspect of the fourth embodiment, the device 
may be a computer, such as a client computer. In addition, the communication 
channel may include a network and the computer may be coupled to the remote 
device via the network. 

According to still yet another aspect of the fourth embodiment, the device 
may be a portable device. The device may also be a wireless device, such as a 
cellular phone. In addition, the wireless device may include a display and the 
processor may control the playback of media content via the display 

According to a fifth embodiment of the present invention, a device is 
provided having a processor executing software instructions including a software 
module. The software module includes a first software playback module that 
controls the playback of media content delivered asynchronously over a 
communication channel by a remote device, wherein the playback of the media 
content is enabled at a predetermined time after the delivery of the media content. 

According to a first aspect of the fifth embodiment, the media content is 
not detectable by a user of the device until the predetermined time. 
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According to another aspect of the fifth embodiment, the delivery of 
media content may be controlled in accordance with a digital rights management 
scheme. 

According to another aspect of the fifth embodiment, the communication 
channel may include a satellite communication channel. 

According to another aspect of the fifth embodiment, the first software 
playback module may control the playback of media content via a display. 
According to another aspect of the fifth embodiment, the device may include a 
display and the first software playback module controls the playback of media 
content via the display. According to still another aspect of the fifth embodiment, 
the first software playback module may include a graphical user interface through 
which the media content is displayed on the display. 

According to another aspect of the fifth embodiment, the media content is 
not detectable by a user of the device until the predetermined time. 

According to still yet another aspect of the fifth embodiment, the software 
module may also include a first software coordination module that coordinates the 
exchange of information with the remote device. The information includes the 
media content. In addition, the information may also include user statistical 
information related to media usage by a user employing the device. According to 
still another aspect of the fifth embodiment, the user statistical information may 
be sent by the device to the remote device to facilitate the delivery of the media 
content to the device. 
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According to another aspect of the fifth embodiment, the device may 
include a storage area that stores media data including the media content. The 
media data may include a number of media files, and the media content may be 
formed from a number of media files in accordance with at least one predefined 
rule. In addition, at least one of the number of media files may be used to form 
distinct media content. 

According to still yet another aspect of the fifth embodiment the software 
module may also include a first registration module that receives user information 
from a user of the device. The device may also transmit the user information to 
the remote device to facilitate the delivery of the media content to the device. 

According to another aspect of the fifth embodiment, the playback of 
media content is controlled based on user input. In addition, the user input may 
be provided to the device using a remote control device which communicates with 
the device. The remote control device may communicate with the device using 
infrared radiation. 

According to still yet another aspect of the fifth embodiment, the software 
module may also include a voice recognition software module, which receives 
user input in the form of voice commands. The voice recognition software 
module converts the voice comftiands into electronic data and provides the first 
software playback module with the electronic data to facilitate the playback of 
media content 

According to sixth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
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asynchronously from a remote device. The device generates a notification for a 
user of the device upon receipt of the media content. The notification may be an 
automatic notification, an audio notification, or an e-mail, for example. 
According to another aspect of the sixth embodiment, the playback of the media 
content is enabled at a predetermined time after the delivery of the media content. 

According to a seventh embodiment of the present invention, a device is 
provided including a processor that controls playback of media content delivered 
asynchronously over a communication channel including a satellite system by a 
remote device. The playback of the media content is enabled at a predetermined 
time after the delivery of the media content 

According to an eighth embodiment of the present invention, a system is 
provided for implementing a media content delivery and playback scheme. The 
system includes a communication channel, a first device and a second device. 
The first device is coupled to the communication channel and includes a first 
processor that controls asynchronous delivery of media content over the 
communication channel. The second device is coupied to the communication 
channel and includes a second processor that controls the playback of media 
content delivered asynchronously over the communication channel by the first 
device, wherein the playback of media content is enabled in the second device at a 
first predetermined time after the delivery of the media content. 

According to one aspect of the eighth embodiment, the media content is 
not detectable by a user of the second device until the predetermined time. 
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According to another aspect of the eighth embodiment, the second device 
may initiate a session with the first device at the predetermined time. The second 
device may initiate the session by making a request for a connection with the first 
device. The first device establishes the connection in response to the request. 
According to another aspect of the eighth embodiment, the first device provides 
the second device with an indication that a user of the second device is entitled to 
the media content. The second device may accept the media content for delivery 
only if it does not already have the media content. 

According to another aspect of the eighth embodiment the first device may 
be a server computer and the second device may be a client computer. 

According to another aspect of the eighth embodiment, the communication 
channel may include at least a portion of a network, such as a local area network 
or a wide area network. In addition, the communication channel may include at 
least a portion of the Internet 

According to another aspect of the eighth embodiment, the second device 
may be a portable device. The portable device may be a wireless device, such as 
a cellular phone. 

According to another aspect of the eighth embodiment communication 
channel includes a wireless network. 

According to another aspect of the eighth embodiment, the delivery of the 
media content from the first device to the second device is controlled in 
accordance with a digital rights management scheme. 
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According to a ninth embodiment of the present invention, a device is 
provided having a processor that controls the delivery of media content over a 
communication channel to a remote device in one of a first mode and a second 
mode. In the first mode, the processor controls the asynchronous delivery of 
media content over the communication channel to facilitate playback of the media 
content through the remote device. In the second mode, the processor controls the 
synchronous delivery of media content over the communication channel to 
facilitate the playback of the media content through the remote device. 

According to a first aspect of the ninth embodiment, the playback of the 
media content is enabled at a predetermined time after the delivery of the media 
content. 

According to another aspect of the ninth embodiment, the device delivers 
the media content 

According to another aspect of the ninth embodiment, the communication 
channel includes a satellite communication channel. 

According to another aspect of the ninth embodiment, the device is a 
server computer. 

According to another aspect of the ninth embodiment, the playback of the 
media content is controlled in accordance with a digital rights management 
scheme. 

According to another aspect of the ninth embodiment, the remote device 
may include a client computer. The remote device may be a portable device, such 
as a wireless device. The wireless device may be a cellular phone. 
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According to a tenth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
over a communication channel by a remote device. The processor controls the 
playback of media content in one of a first mode and a second mode. In the first 
mode, the processor controls the playback of media content delivered 
asynchronously by the remote device. In the second mode, the processor controls 
the playback of media content delivered synchronously by the remote device. 
According to a first aspect of the tenth embodiment, the playback of the 

media content is enabled at a predetermined time after the delivery of the media 

content. 

According to another aspect of the tenth embodiment, the media content is 
not detectable by a user of the device until the predetermined time. 

According to an eleventh embodiment of the present invention, a device 
is provided having a processor that controls the delivery of media content over a 
communication channel to a remote device in one of a first mode and a second 
mode. In the first mode, the processor controls the unicast-based delivery of 
media content over the communication channel to facilitate playback of the media 
content through the remote device. In the second mode, the processor controls the 
multicast-based delivery of media content over the communication channel to 
facilitate the playback of the media content through the remote device. 

According to another aspect of the eleventh embodiment, the playback of 
the media content is enabled at a predetermined time after the delivery of the 
media content. 
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According to another aspect of the eleventh embodiment, the device may 
deliver the media content. 

According to another aspect of the eleventh embodiment, the 
communication channel includes a satellite communication channel. 

According to another aspect of the eleventh embodiment, the device may 
be a server computer. 

According to another aspect of the eleventh embodiment, the playback of 
the media content may be controlled in accordance with a digital rights 
management scheme. 

According to another aspect of the eleventh embodiment, the remote 
device may include a client computer. In addition, the remote device may be a 
portable device, such as a wireless device. The wireless device may be a cellular 
phone. 

According to a twelfth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
over a communication channel by a remote device. The processor controls the 
playback of media content in one of a first mode and a second mode. In the first 
mode, the processor controls the playback of media content delivered by the 
remote device via a unicast mode of delivery. In the second mode, the processor 
controls the playback of media content delivered by the remote device via a 
multicast mode of delivery. 
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According to a first aspect of the twelfth embodiment, the playback of the 
media content is enabled at a predetermined time after the delivery of the media 
content. 

According to another aspect of the twelfth embodiment, the media content 
is not detectable by a user of the device until the predetermined time. 

According to a thirteenth embodiment of the present invention, a device is 
provided having a processor that controls asynchronous delivery of media content 
over a communication channel to facilitate playback of the media content through 
a remote device. The device receives a request for a connection from the remote 
device, establishes the connection in response to the request, provides the remote 
device with a first indication that a user of the remote device is entitled to the 
media content, and receives from the remote device a second indication that the 
remote device will accept the media content for delivery unless the remote device 
already has the media content. 

According to a first aspect of the thirteenth embodiment, the first 
indication includes a first list of a first group of media content items including at 
least a first media content item, which is the media content 

According to another aspect of the thirteenth embodiment, the second 
indication includes a second list of a second group of media content items 
including at least a second media content item, which is the media content. The 
second group of media content items includes a number of media content items 
including at least the second media content item. The second group of media 
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content items is a group of media content items that the remote device will accept 
for delivery from the device. 

According to a fourteenth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
asynchronously over a communication channel by a remote device. The device 
makes a request for a connection to the remote device, receives a connection from 
the remote device in response to the request, receives a first indication from the 
remote device that a user of the device is entitled to the media content from the 
remote device, and provides a second indication to the remote device that the 
device will accept the media content for delivery unless the device already has the 
media content. 

According to a first aspect of the fourteenth embodiment, the first 
indication includes a first list of a first group of media content items including at 
least a first media content item, which is the media content. 

According to another aspect of the fourteenth embodiment, the second 
indication includes a second list of a second group of media content items 
including at least a second media content item, which is the media content The 
second group of media content items includes a number of media content items 
including at least the second media content item. The second group of media 
content items is a group of media content items that the device will accept for 
delivery from the remote device. 

According to a fifteenth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
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asynchronously over a communication channel by a remote device. Hie device is 
capable of providing an indication to another on behalf of a user of the device, the 
indication being of a location where the media content may be found. 

According to a sixteenth embodiment of the present invention, a device is 
provided having a processor that controls playback of media content delivered 
asynchronously over a communication channel by a remote device. The device is 
capable of providing a portion of the media content to another on behalf of a user 
of the device. The portion of the media content may be provided as an attachment 
to an e-mail. 

According to an seventeenth embodiment of the present invention, a 
computer program product is provided for use in a device having a processor for 
executing software instructions. The computer program product includes a 
computer usable medium having computer readable program code means 
embodied therein for causing the device to control the asynchronous delivery of 
media content over a communication channel to facilitate playback of the media 
content through a remote device. The playback of the media content is enabled at 
a first predetermined time after the delivery of the media content 

According to a eighteenth embodiment of the present invention, a 
computer program product is provided for use in a device having a processor for 
executing software instructions. The computer program product includes a 
computer usable medium having computer readable program code means 
embodied therein for causing the device to control playback of media content 
delivered asynchronously over a communication channel by a remote device. The 
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playback of the media content is enabled at a predetermined time after the 
delivery of the media content. . 

According to a nineteenth embodiment of the present invention, a method 
of implementing a media content delivery and playback scheme is provided. The 
method includes the step of delivering media content asynchronously via a 
communication channel for remote playback of the media content. The remote 
playback of the media content is enabled at a predetermined time after the 
delivery of the media content. 

According to a first aspect of the nineteenth embodiment, the media 
content is not detectable until the predetermined time. 

According to another aspect of the nineteenth embodiment, the method 
also includes the steps of receiving the media content; and enabling the playback 
of the media content at the predetermined time. 

According to another aspect of the nineteenth embodiment, the method 
also includes the step of conducting the playback of the media content after 
enabling the playback of the media content at the predetermined time. 

According to another aspect of the nineteenth embodiment, the step of 
conducting may include the step of displaying the media content 

According to a twentieth embodiment of the present invention, a method 
of implementing a media content delivery and playback scheme is provided. The 
method includes the steps of receiving media content which is delivered 
asynchronously via a communication channel; and enabling playback of the 
media content at a predetermined time after the receipt of the media content 
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According to a first aspect of the twentieth embodiment, the method includes the 
step of detecting the media content at the predetermined time. 

According to another aspect of the twentieth embodiment, the method 
includes the step of providing a notification of receipt of the media content. 

It is to be understood that both the foregoing general description and the 
following detailed description are exemplary and explanatory and are intended to 
provide further explanation of the invention as claimed. 

BRIEF DESCRIPTION OF THE DRAWINGS 

These and other features, aspects and advantages of the present invention 
will become better understood with reference to the following description, 
appended claims, and accompanying drawings, in which: 

Figure 1 depicts a system for implementing a media content delivery and 
playback scheme in accordance with an embodiment of the present invention. 

Figure 2 depicts the components of a software module that may be 
employed in a first device in accordance with an embodiment of the present 
invention. 

Figure 3 depicts the components of a software module that may be 
employed in a second device in accordance with an embodiment of the present 
invention. 

Figure 4 depicts a flow chart featuring the steps of an embodiment of the 
present invention. 
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Figure 5 depicts another flow chart featuring the steps of another 
embodiment of the present invention. 

Figure 6 depicts a system in accordance with a preferred embodiment of 
the present invention. 

Figure 7a depicts an aspect of a graphical user interface of a software 
playback module employed in a client computer of the system depicted in Figure 
6. 

Figure 7b depicts another aspect of the graphical user interface shown in 
Figure 7a. 

Figure 8 depicts a protocol for communications between a client computer 
and a server computer in the system depicted in Figure 6. 

Figure 9 depicts another protocol for communications between a client 
computer and a server computer in the system depicted in Figure 6. 

Figure 10 depicts classes of objects and their corresponding attributes for 
objects stored in a database of the system depicted in Figure 6. 

Figures 11 through 23 depict the files, dates of creation, and size in bytes 
of the compact disc appendix. 

DETAILED DESCRIPTION OF THE PREFERRED 
EMBODIMENTS 

The present invention is directed to devices, methods and a system for 
implementing a media content delivery and playback scheme. In particular, the 
present invention provides for the delivery of media content (including, for 
example, audio and video) asynchronously via a network to facilitate playback of 
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the media content through a remote device (e.g., user-owned, client computer). 
The invention is implemented through the asynchronous delivery of media 
content by proactively storing media content to a remote device. However, the 
present invention may also support two modes of delivery: an asynchronous mode 
and a synchronous mode. Preferably, the delivery of media content is based on a 
user-generated content preference. 

Figure 1 shows a system 100, which implements a media content delivery 
and playback scheme in accordance with the present invention. The system 100 
includes a first device 110 and a second device 120 coupled by a communication 
channel 130. The first device 110 and the second device 120 may be 
implemented in computer systems (not shown), which include those devices 110 
and 120. The first device 110 is coupled to the communication channel 130 and 
includes a first processor 140 that controls asynchronous delivery of media 
content over the communication channel 130. The second device 120 is coupled 
to the communication channel 130 and includes a second processor 150 that 
controls the playback of media content delivered asynchronously over the 
communication channel 130 by the first device 110 (or a device controlled by the 
first device 110). 

The playback of media content is enabled in the second device 120 at a 
first predetermined time after the delivery of the media content. In addition, the 
media content may not be detectable by a user of the second device 120 until the 
predetermined time. Preferably, the delivery of media content from the first 
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device 110 (or a device controlled by the first device 110) to the second device 
120 is controlled in accordance with a digital rights management scheme. 

The devices 110 and 120 of the system 100 may, for example, operate in 
the following manner. The second device 120 may initiate a session with the first 
device 110 at the predetermined time. The second device 120 initiates the session 
by making a request for a connection with the first device 110. The first device 
110 establishes the connection in response to the request. The first device 110 
provides the second device with an indication that a user of the second device 120 
is entitled to the media content. The second device 120 may accept the media 
content for delivery only if it does not already have the media content. 

In the system 100, the first device 110 may be a server computer and the 
second device 120 maybe a client computer. However, the system may be 
operated as a peer-to-peer system, in which either the first device 110 or the 
second device 120 operates as a servo: with respect to the other, which operates as 
the client. The first device 110 and/or the second device 120 may be a portable 
device. The portable device may be a wireless device, such as a cellular phone 
with or without a display. 

The processor 150 of the second device 120 may control the playback of 
media content via a display. By way of example, the second device 120 may have 
associated with it a display 125 and the second processor 150 may control the 
playback of media content via the display 125. Although the display 125 is 
shown as being part of the device 120, the display 125 may be coupled to the 
device 120. 
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The communication channel 130 may include at least a portion of a 
network, such as a local area network, wide area network, public network (e.g., 
the Internet), a wireless network, or a combination of networks. The 
communication channel 130 may also include a satellite communication channel, 
including a satellite communication system. If the communication channel 130 
includes at least part of a network, the first device 110 and the second device 120 
may be coupled to each other via the network. In addition, if the communication 
channel 130 utilizes a satellite communication system, a satellite communication 
system may be used in the system 100 which is similar to those featured in U.S. 
Patent No. 6,016,388 and U.S. Patent No. 6,205,473, which are incorporated 
herein by reference. 

As noted above, the first device 110 includes a processor 140 that controls 
asynchronous delivery of media content over a communication channel to 
facilitate playback of the media content through a remote device (e.g. 9 the second 
device 120). The processor 140 executes software instructions, which, in 
accordance with one embodiment of the present invention, may include a software 
module 160, as shown in Figures 1 and 2. The first device 110 may also include 
a memory portion 170 that stores at least a portion of the software module. 

The software module 160 includes a software delivery module 200 that 
controls asynchronous delivery of media content over a communication channel 
to facilitate playback of the media content through the remote device. The 
playback of the media content is enabled at a first predetermined time after the 
delivery of the media content. 
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The software delivery module 200 may, for example, generate indicator 
data for the remote device that provide an indication of a second predetermined 
time when the media content will be delivered to the remote device. The first 
device 110 delivers the media content to the remote device at the second 
predetermined time. As noted above, the remote device may initiate a session 
with the software delivery module just prior to the second predetermined time. 
The remote device initiates the session by making a request for a connection with 
the first device 110. The first device 110 may establish the connection in 
response to the request. The first device 110 then provides the remote device with 
an indication that a user of the remote device is entitled to the media content. The 
remote device then accepts the media content for delivery unless the remote 
device already has the media content 

The software module 160 may also include a software recovery module 
210, which provides control information to the software delivery module 200 to 
enable the automatic delivery of disrupted data without delivering data that has 
already been successfully delivered to the remote device. 

The software module 160 may also include a software database interface 
module 220 that processes requests to retrieve information from a database (not 
shown) including media content information related to the media content. The 
software database interface module 220 may receive a request for the information 
from the remote device, submit the request to the database, receive the 
information from the database, and send the information to the remote device. 
The software database interface module 220 may also receive a request for the 
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information from the software delivery module 200, submit the request to the 
database, receive the information, and send the information to the software 
delivery module 200 to facilitate the delivery of the media content to the remote 
device. 

The media content information may include at least an identifier 
identifying a media category with which the media content is associated. The 
media category may be a segment of an episode, an episode, a series, or a package 
with which the media content is associated. The package may be defined in 
accordance with user statistical information related to media usage by a user 
employing the remote device. The software delivery module 200 may control the 
delivery of the media content based on user statistical information concerning 
media usage by a user employing the remote device. The software delivery 
module 200 may control the delivery of the media content in segments, each 
having a size that depends on the user statistical information. 

The software module 160 may also include a software user interface 
module 230 that processes requests for the information from a user of the remote 
device and submits the requests for the information to the software database 
interface module 220 for retrieval from the database. The software user interface 
module 230 may include a graphical user interface 240. The graphical user 
interface 240 may be implemented via a web site. 

The software module 160 may also include a software storage module 250 
that facilitates the storage of media content in a media content repository (not 
shown) by a content provider. The software database interface module 220 may 



-25- 



WO 03/010634 



PCT/US02/23713 



receive a request for the information from the software storage module 250, 
submit the request to the database, receive the information from the database, and 
send the information to the software storage module 250 to facilitate storage of 
the media content in the media content repository. 

The software module 160 may also include a software content provider 
interface module 260 that processes requests for the information from a content 
provider and submits the requests for the information to the software database 
interface module 220 for retrieval from the database. The software content 
provider interface module 260 may include a graphical user interface 270. The 
graphical user interface 270 may be implemented via a web site. 

The software module 160 described above in connection with the first 
device 110 may be stored on a computer program product in accordance with the 
present invention. By way of example, the computer program product includes a 
computer usable medium having computer readable program code means 
embodied therein for causing the first device 110 to control the asynchronous 
delivery of media content over a communication channel to facilitate playback of 
the media content through a remote device (e.g., the second device 120). The 
playback of the media content is enabled at a first predetermined time after the 
delivery of the media content 

As noted above, the second device 120 includes a processor 150 that 
controls playback of media content delivered asynchronously over a 
communication channel by a remote device (e.g., the first device 110). The 
processor 150 executes software instructions, which, in accordance with one 
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embodiment of the present invention, may include a software module 180, as 
shown in Figures 1 and 3. The second device 120 may also include a memory 
portion 190 that stores at least a portion of the software module 180. 

The software module 180 includes a first software playback module 300 
that controls the playback of media content delivered asynchronously over a 
communication channel by a remote device, wherein the playback of the media 
content is enabled at a predetermined time after the delivery of the media content. 
In addition, the media content may not be detectable by a user of the second 
device 120 until the predetermined time. 

The media content may be distributed from the second device to another 
device (e.g., portable device). The distribution of the media content may be 
controlled in accordance with a digital rights management scheme, as set forth 
below. 

The first software playback module 300 may control the playback of 
media content via a display. As noted above, the second device 120 may include 
a display 125 arid the first software playback module 300 may control the 
playback of media content via the display 125. The first software playback 
module 300 may include a graphical user interface 310 through which the media 
content is displayed on the display 125. 

The software module 180 may also include a first software coordination 
module 315 that coordinates the exchange of information with the remote device. 
The information includes the media content. In addition, the information may also 
include user statistical information related to media usage by a user employing the 
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second device 120. The user statistical information may be sent by the second 
device 120 to the remote device to facilitate the delivery of the media content to 
the second device 120. 

The second device 120 may include a storage area (not shown) that stores 
media data including the media content. The media data may include a number of 
media files, and the media content may be formed from a number of media files in 
accordance with at least one predefined rule . In addition, at least one of the 
number of media files may be used to form distinct media content. 

The software module 180 may also include a first software registration 
module 318 that receives user information from a user of the second device 120. 
The second device 120 may also transmit the user information to the remote 
device to facilitate the delivery of the media content to the second device 120. 

The playback of media content is controlled based on user input. In 
addition, the user input may be provided to the second device 120 using a remote 
control device (not shown) that communicates with the device. The remote 
control device may communicate with the device using infrared radiation in a 
manner well known in the art. 

The software module 180 may also include a voice recognition software 
module 320, which receives user input in the form of voice commands. The voice 
recognition software module 320 converts the voice commands into electronic 
data and provides the first software playback module 300 with the electronic data 
to facilitate the playback of media content Several voice recognition techniques 
which are known to those skilled in the art, may be implemented in the voice 
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recognition software module 320. Examples of such voice recognition techniques 
are featured in U.S. Patent No. 6,094,635, U.S. Patent No. 6,154,722, and U.S. 
Patent No. 6,260,012, which are incorporated herein by reference. 

The software module 180 described above in connection with the second 
device 120 may be stored on a computer program product in accordance with 
present invention. By way of example, the computer program product may 
include a computer usable medium having computer readable program code 
means embodied therein for causing the second device 120 to control playback of 
media content delivered asynchronously over a communication channel by a 
remote device (e.g., the first device 110). The playback of the media content is 
enabled at a predetermined time after the delivery of the media content. 

As an alternative to the second device 120, a third device (not shown) may 
be employed in the system 100. The third device includes a processor that 
controls playback of media content delivered asynchronously from a remote 
device. In addition, the third device generates a notification for a user of the 
device upon receipt of the media content. The notification may be an automatic 
notification, an audio notification, or an e-mail, for example. As with the second 
device, the playback of the media content may be enabled at a predetermined time 
after the delivery of the media content. Similarly, the media content may not be 
detectable by a user of the third device until the predetermined time. 

The processors 140 and 150 of the first device are capable of operating in 
multiple modes, as described below. The processor 140 of the first device 110 
may control the delivery of media content over a communication channel 130 to a 
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remote device (eg., the second device 120) in one of a first mode and a second 
mode. In the first mode, the processor 140 controls the asynchronous delivery of 
media content over the communication channel 130 to facilitate playback of the 
media content through the remote device. In the second mode the processor 140 
controls the synchronous delivery of media content over the communication 
channel 130 to facilitate the playback of the media content through the remote 
device. 

The processor 140 of the first device 110 may control the delivery of 
media content over the communication channel 130 to a remote device (e.g., the 
second device 120) in one of a first mode and a second mode. In the first mode, 
the processor 140 controls the unicast-based delivery of media content over the 
communication channel 130 to facilitate playback of the media content through 
the remote device. In the second mode, the processor 140 controls the multicast- 
based delivery of media content over the communication channel 130 to facilitate 
the playback of the media content through the remote device. 

A synchronous mode of delivery refers to the delivery of media content in 
a manner in which the media content is being played back (i.e., watched or 
listened) at nearly the same time it is being delivered. With respect to a 
communication channel 130, such as a digital network or the Internet, digital data 
is stored momentarily in memory buffers before being played back. This mode of 
delivery is typically referred to as media streaming and the contents of the 
memory buffers do not survive the playback session. In contrast, an 
asynchronous delivery mode refers to the delivery of robust media content files 
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which survive the playback session. In this regard, the media content files are 
delivered "asynchronously" - i.e., without respect to time. Both the unicast and 
multicast-based mode of delivery are synchronous delivery nodes. 

A unicast mode of delivery refers to point-to-point interactive 
communication over the communication channel 130, (e.g. 5 the Internet). The first 
device 110 (e.g., a server computer) and the second device 120 (e.g., a client 
computer) are holding a private and interactive session with each other. In this 
manner, the second device 120 can request a specific media content item, and the 
first device 110 delivers that media content item solely to the second device 120. 
In a multicast mode of delivery, the first device 110 broadcasts the media content 
items to all devices (including the second device 120) in the communication 
channel 130. The only way that the first device 110 can control which devices can 
utilize those media content items is to utilize a digital rights management scheme. 
By way of example, the media content items may be encrypted and encryption 
keys distributed to specific devices. The encryption keys are specifically matched 
to a unique receiver ID. This is the basis for conventional conditional access 
systems that are used to control cable and satellite TV access in a manner well 
known in the art. 

The processor 150 of the second device 120 may control the playback of 
media content delivered over the communication channel 130 by a remote device 
(e.g., the first device 110). The processor controls the playback of media content 
in one of a first mode and a second mode. In the first mode, the processor 
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controls the playback of media content delivered asynchronously by the remote 
device. In the second mode, the processor controls the playback of media content 
delivered synchronously by the remote device. 

The processor 150 of the second device 120 controls the playback of 
media content delivered over the communication channel 130 by a remote device 
{e.g., the first device 110). The processor 150 controls the playback of media 
content in one of a first mode and a second mode. In the first mode, the processor 
150 controls the playback of media content delivered by the remote device via a 
unicast mode of delivery. In the second mode, the processor 150 controls the 
playback of media content delivered by the remote device via a multicast mode of 
delivery. 

The processor 140 of the first device 110 may control the asynchronous 
delivery of media content, as follows. The first device 110 receives a request for 
a connection from a remote device (e.g., the second device 120). Thereafter, the 
first device 110 establishes the connection in response to the request of the remote 
device and provides the remote device with a first indication that a user of the 
remote device is entitled to the media content Then, the first device 110 receives 
from the remote device a second indication that the remote device will accept the 
media content for delivery unless the remote device already has the media 
content 

The first indication may include a first list of a first group of media 
content items including at least a first media content item, which is the media 
content. The second indication may include a second list of a second group of 
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media content items including at least a second media content item, which is the 
media content. The second group of media content items includes a number of 
media content items including at least the second media content item. The second 
group of media content items is a group of media content items that the remote 
device will accept for delivery from the device. 

The processor 140 of the second device 120 may control the playback of 
media content delivered asynchronously over the communication channel 130 by 
a remote device (e.g., the first device 110) as follows. The second device 120 
makes a request for a connection to the remote device. Thereafter, the second 
device 120 receives a connection from the remote device in response to the 
request. The second device 120 receives a first indication from the remote device 
that a user of the second device 120 is entitled to the media content from the 
remote device. Then, the second device 120 provides a second indication to the 
remote device that the second device 120 will accept the media content for 
delivery unless the second device 120 already has the media content 

The first indication may include a first list of a first group of media 
content items deluding at least a first media content item, which is the media 
content The second indication may include a second list of a second group of 
media content items including at least a second media content item, which is the 
media content. The second group of media content items includes a number of 
media content items including at least the second media content item. The second 
group of media content items is a group of media content items that the second 
device 120 will accept for delivery from the remote device. 
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Two additional alternatives for the second device 120 will now be 
described to highlight two additional features of the present invention. In one of 
the additional alternatives, a fourth device (not numbered) is provided having a 
processor (not numbered) that controls playback of media content delivered 
asynchronously over a communication channel by a remote device. The device is 
capable of providing an indication to another on behalf of a user of the device, the 
indication being of a location where the media content may be found. By way of 
example, the indication may be a URL address. In another of the additional 
alternatives, a fifth device is provided having a processor that controls the 
playback of media content delivered asynchronously over a communication 
channel by a remote device. The device is capable of providing a portion of the 
media content to another on behalf of a user of the device. The portion of the 
media content may be provided as an attachment to an e-maiL 

Figure 4 shows a flow chart featuring the steps of a method of 
implementing a media content delivery and playback scheme in accordance with 
the present invention. The method includes the step 400 of delivering media 
content asynchronously via a communication channel for remote playback of the 
media content. The remote playback of the media content is enabled at a 
predetermined time after the delivery of the media content. In addition, the media 
content may not be detectable until the predetermined time. In step 410, media 
content is received. Thereafter, in step 420, the playback of the media content is 
enabled at the predetermined time. The method may also include the step 430 of 
conducting the playback of the media content after enabling the playback of the 
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media content at the predetermined time. The step of conducting may include the 
step (not shown) of displaying the media content. 

Figure 5 shows a flow chart featuring the steps of a method of 
implementing a media content delivery and playback scheme in accordance with 
the present invention. The method includes the step 500 of receiving media 
content which is delivered asynchronously via a communication channel, and the 
step 510 of enabling the playback of the media content at a predetermined time 
after the receipt of the media content. The method may also include the step 503 
of providing a notification of the receipt of the media content. In addition, the 
method may also include the step (not shown) of detecting the media content at 
the predetermined time, in which case, the notification Step 503 will not occur 
until the media content is detected. 

Figure 6 depicts a system 600 for implementing a media content delivery 
and playback scheme in accordance with a preferred embodiment of the present 
invention. The system includes a server computer system 610 including at least a 
server computer (not shown) having a first processor (not shown). The system 
also includes a client computer system 620 including at least a client computer 
(not shown) having a processor (not shown). In addition, the system 600 includes 
at least a portion of a network 630 by which the server computer system 610 and 
the client computer system 620 are coupled to each other. The network 630 may 
be implemented as a local area network, wide area network, a public access 
network (e.g., the Internet), or a combination of networks. 
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Both the server and client computers may be implemented as a portable 
device (e.g., a personal digital assistant), a wireless device, or a portable wireless 
device cellular phone or pager). In addition, although the system 600 is 
described as a server/client based system, it may also be anranged as a peer-to- 
peer system, in which each device acts as server with respect to the other device, 
which, in turn, acts as a client. 

The processor of the server computer executes instructions including a 
first software module 632, which' may be stored in a storage device associated 
with the server computer, or on another device with which the server computer is 
networked. The storage device may include a hard drive, random access memory, 
read only memory, a redundant array of inexpensive disks (RAID), an optical 
disk, a CD-ROM, WORM, floppy disk, or any of a number of storage devices, 
which are well known to those skilled in the art. 

The first software module 632 includes a software delivery module 635 
that controls asynchronous delivery of media content over the network 630 to 
facilitate playback of the media content through the client computer. By storing 
the media content on the client computer (Le. 9 a remote device), which is local to 
the user of the client computer, the system 600 avoids the inconsistent quality that 
may result from streaming media content over the network 630. By downloading 
media content in the form of media files automatically, the system 600 eliminates 
the tedium of hunting for media files and manually downloading them. la 
addition, the playback of the media content may, in accordance with one aspect of 
the preferred embodiment, only be enabled at a predetermined time after the 
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delivery of the media content. In addition, the media content may not be 
detectable by a user of the client computer until the predetermined time. 

Preferably, the software delivery module 635 waits to be contacted by the 
client computer and then interacts with the client computer to coordinate the 
delivery of media content to the client computer and to coordinate the receipt of 
user statistical information back from the client computer. 

Since the system 600 relies on the download of media content to an often 
unattended client computer, there may be media content items that are 
downloaded to the client computer that a user of the client computer will never 
use. Thus, if the server computer delivered media content items in their entirety, 
the useable bandwidth for the network 630 may not be allocated efficiently. The 
first software module 632 may include an adaptive download module (not shown) 
that monitors the user's actual consumption patterns and determines the media 
content items that have a higher probability of being consumed or of not being 
consumed. For those media content items that do not have a high probability of 
being consumed, the adaptive download module would only download portions of 
those content items or perhaps cease downloading them altogether. Thus, the 
total bandwidth load for the network 630 would be reduced. 

The server computer may incorporate a database 640 (e.g., a PostgreSQL 
relational database), or it may have access to the database 640, which may be 
residing on a storage device within the server computer system 610, or which may 
be otherwise accessible via the network 630. The database 640 stores information 
related to the system in the form of metadata. The information must include 
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metadata about the media content available to the system, including for example, 
descriptions of packages, series and episodes. The information should also 
include metadata that relates to users of the system. This metadata may include, 
for example, account information, billing history and statistics. The database need 
not contain the media files themselves. As an alternative, the media files may be 
stored within a first content repository 645 associated with the server computer 
system 610. The contents of the first content repository 645 may be accessible 
via the database 640. 

The first software module 632 may also include a software user interface 
module 650 and a software content provider interface module 655. These are the 
public interfaces for users, advertisers and content providers. These interfaces 
may be operated as graphical user interfaces that are implemented as web sites or 
web portals. By way of example, users would use the software user interface 
module 650 to change their subscriptions, view billing histories, or view the 
available media content (as represented by, for example, episodes, shows, series 
or pre-defined packages). In addition, the content provider interface module 655 
may be accessed by a content provider via a web browser 657 residing on a client 
computer 658 of the content provider. 

The software interface module 650 may also be implemented with a 
program guide, which would allow users of the client computer to preview media 
content items. The program guide would allow the user to preview selected 
media content items by streaming those items (e.g. y audio or video content items) 
to the client computer. A clickable hyperlink in the program guide will launch the 
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user's streaming media player of choice and allow them to read, listen, or see the 
media content item before subscribing. In addition, content providers may use a 
software content provider interface module 655, to upload new content and view 
summary statistics about how their shows were being used by users of the system 
600. 

The processor of the client computer executes instructions including a 
second software module which may be stored in a storage device associated with 
the client computer, or on another device with which the client computer is 
networked. The storage device may include a hard drive, random access memory, 
read only memory, a redundant array of inexpensive disks (RAID), an optical 
disk, a CD-ROM, WORM, floppy disk, or any of a number of well-known storage 
devices, which are well known to those skilled in the art. 

The second software module 659 includes a first software playback 
module 660 that controls the playback of media content delivered asynchronously 
over the network 630 by the server computer. The first software playback module 
660 includes a graphical user interface 700, as shown in Figure 7a, that allows 
the user to view, organize and play back media content. In particular, the 
graphical user interface 700 of the first software playback module 660 may 
include various windowpanes. By way of example, there may be a Folders Pane 
705 that displays various folders for storing and organizing messages (e.g., an 
Inbox folder 710, a Saved folder 715 and a Trash folder 717). There may also be 
a List Pane 720 that lists the media content items contained in a selected folder. 
By way of example, the List Pane 720 may identify the Show, Episode number, 
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Description, Receive Date and Publish Date of the media content items in the 
Inbox folder 710. In addition, there may also be a Detail Pane 730 that displays 
detailed information about a media content item highlighted in the List Pane 720. 
A user can move media files by dragging those media files and dropping them 
into specific folders. 

The second software module also includes a first software coordination (or 
synchronization) module 665 that coordinates the exchange of information with 
the server computer. The first software coordination module 665 contacts the 
server computer and coordinates the delivery of any new media content files for a 
user of the client computer. The first software coordination module 665 also 
uploads user statistics back to the server computer. Using a client computer in 
accordance with the present invention, a user can have access to a wide variety of 
media content, including original and re-purposed data, music, videos and multi- 
media programming. 

A variety of types of programming may be supported using the system 600 
of the present invention. These types of programming include, for example, stock 
reports, news items, emergency reports, cartoons, movies, data reports, product 
reports and detailing, talk shows, music programs, do-it-yourself and repair 
information, horoscopes, audiobooks, news information, sports information, 
weather information, political information, dramas, NASCAR shows, personal 
relationship information and business reporting. The media content may also 
contain advertisements. In addition to or as an alternative to the use of 
advertisements, media content may be provided on a fee for content basis. 
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The second software module 659 also includes a software configuration 
module 670. A user of the client computer can use the configuration module 670 
to configure the software module, as desired. 

The second software module also includes a software registration module 
(not specifically shown) that receives user information from a user of the client 
computer. The registration module may be implemented as a web browser 680 
through which a user of the client computer can interact with the server computer 
to register or obtain information about media content or the user's account status. 
The client computer then transmits the user information to the server computer to 
facilitate the delivery of media content to the client computer. 

The second software module may also access a local content repository 
685 to store media content in the form of media files. The local content 
repository 685 may be a storage device, such as a hard drive, random access 
memory, a redundant array of inexpensive disks (RAID), an optical disk, a CD- 
RW, WORM, floppy disk, or any of a number of storage devices that are well 
known to those skilled in the art 

Initially, a new user will register with the system 600 using the web 
browser 680. The new user registration process is a one-time event for each user. 
Using the web browser 680, a new user will access the server computer's software 
user interface module 650, which is implemented as a web site (or web portal) for 
end-users. When accessing the server client's web site, the user is prompted to 
become a system user in accordance with a registration process. In particular, the 
user fills out an on-screen HTML or XML form (not shown) with various pieces 
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of information including, for example: the user's name, address, e-mail address, 
credit card information, etc. The server computer uses this information to 
uniquely identify each of its users to: (a) ensure that the user gets the content they 
requested; (b) ensure that an administrator of the system gets paid for the services 
it renders; and (c) provide the system with valuable information for further use 
(e.g., e-mail addresses for new show notifications). 

Once registered, a user would next receive the second software module 
659. The user may receive the second software module 659 by downloading it 
from the server computer's software user interface module 650 to the client 
computer. A variant on this process would be to distribute the second software 
module to the user on a storage device, such as a CD-ROM. Thus, instead of 
downloading the second software module from the server computer's user 
interface module 650, a user would install the second software module from the 
storage device. A user would agree to the terms and conditions of use for the 
second software module and install it on the client computer. 

Once the user was registered and had the second software module installed 
on the client computer, the user would access the server computer's software user 
interface module 650 via the web browser 680 and identify the media content that 
the user wishes to receive. This would occur by selecting content from the 
software user interface module 650. The resulting user selection profile is stored 
in the database 640. 

Encoded in the second software module is the address (e.gi, IP address) 
for the server computer. The client computer uses this address to contact the 



-42- 



WO 03/010634 



PCT/US02/23713 



server computer and establish a connection. Once the connection is made, the 
client sends information that uniquely identifies that user. 

The client computer may contact the server computer on a fixed time 
interval (e.g., every 15 minutes). Further, the server computer can also provide 
the client computer with an indication of a predetermined time when the client 
computer can expect the next piece of content to arrive. This later technique is 
particularly efficient at handling "special bulletins" and other content that is made 
available outside of a regular schedule of programming, for example. 

Once the client computer identifies the user to the server computer, the 
server computer takes that information and queries the database 640 for all 
content to which that user is subscribed. The server computer then sends this 
entire list to the client. This is done so that the client computer can display on the 
graphical user interface 700 of the first software playback module 660 a progress 
bar, which indicates how many items have been received and how many are yet to 
come. 

The server computer then proceeds to offer every one of these content 
items to the client computer for download. The client computer checks to see if it 
already possesses the specific media content in the form of a media file. If the 
client computer possesses the specific media content item, then the client 
computer refuses the download offer and the server computer skips to the next 
item on the list. If the client computer does not have the media content item, then 
the client computer accepts the download of the media content item from the 
server computer and stores the media content in the local content repository 685. 
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Although generally described above, the client and server computers may 
interact in accordance with one of two protocols. The first protocol is illustrated 
in Figure 8. In step 800, the client computer contacts the server computer and 
requests a connection. In step 810, the server computer accepts and establishes 
the connection. Thereafter, in step 820, the client computer sends . user 
information to the server. Thereafter, in step 825, the server computer uses the 
user information to query the database 640. In step 830, the database responds 
with a list of all content to which that user is entitled. In step 840, the server 
computer sends the list to the client. Thereafter, in step 850, the server computer 
attempts to send a first media content item on the list to the client computer. In 
step 860, the client computer determines if it already has the media content item 
stored in the local content repository 685. If the client computer does have the 
media content item, then in step 870, the client computer provides an indication to 
the server computer that it currently has the media content item, such that the 
server computer will offer the next media item on the list If the client computer 
does not have the media content item, then in step 880, the client computer 
accepts the media content item from the server computer. Thereafter, steps 850- 
880 are repeated for each media content item, as necessary. 

After the media content item has been successfully downloaded, in step 
880, the step 885 may be performed as an additional option, in which the server 
computer stores in the database 640 an indication that the media content item has 
been successfully downloaded to the client computer. Thus, when the server 
queries the database about which items to offer for future download to the client 
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computer, the database 640 will return only those items which have not already 
been downloaded to the client computer, rather than a comprehensive list of all 
media content items to which a user of the client computer may be entitled. 

The second protocol is illustrated in Figure 9. In step 900, the client 
computer contacts the server computer and requests a connection. In step 910, the 
server computer accepts and establishes the connection. Thereafter, in step 920, 
the client computer sends user information to the server. In step 925, the client 
computer would request a list of content that should be delivered. In step 927, the 
server computer uses the user information to query the database 640. In step 930, 
the database 640 responds with a first list of all content to which that user is 
entitled, which may be implemented as, for example, XML file. In step 940, the 
server computer sends the first list to the client computer. Thereafter, in step 945, 
the client computer identifies those media content items on the first list that it 
does not already have in the local content repository 685. In step 947, the client 
computer would send a second list of only those media content items contained in 
the first list that it currently does not have stored in the local content repository 
685. In step 950, the server computer delivers those media content items 
contained in the second list to the client computer. 

After the media content items have been successfully delivered, in step 
950, the step 960 may be performed as an additional option, in which the server 
computer stores in the database 640 an indication that the media content item has 
been successfully downloaded to the client computer. Thus, when the server 
queries the database about which items to offer for future download to the client 
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computer, the database 640 will return only those items which have not already 
been downloaded to the client computer, rather than a comprehensive list of all 
media content items to which a user of the client computer may be entitled. 

Once a media content item has been successfully downloaded to the client 
computer's local content repository 685, the new media content item will appear 
in the graphical user interface 700 of the first software playback module 660. In 
particular, the media content item will appear in the Inbox folder 710 of the 
graphical user interface 700 along with other media content items that have 
already been downloaded from the server computer. 

Typically, a user would start by checking their Inbox folder 710 for new 
media content. The graphical user interface 700 of the first software playback 
module 660 displays new, unused content items in the List Pane 720 in 
highlighted text, and read/listened/viewed items in normal un-highlighted text. If 
a user clicked a single time on a particular media content item appearing in the 
List Pane 720 using a mouse associated with the client computer, details about the 
selected media item would appear in the Detail Pane 730. To delete a media 
content item, a user would either drag the item using a mouse to the Trash folder 
717, or select the content item and press the DELETE key on a keyboard 
associated with the client computer. In addition, users of the client computer can 
manage media content items by creating folders in the Folders Pane 705 and then 
dragging and dropping media content items into those folders. 

To playback a media content item (e.g., read, listen, or view a media 
content item), a user would double click on it in the List Pane 720 using a mouse. 
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This action would initiate a separate media playback window appearing in the 
graphical user interface 700 with discrete control functions (e.g., "PLAY," 
"STOP," "PAUSE," "FORWARD," "REVERSE," and "RECORD" control 
functions). In addition, as noted above, the discrete control functions may be 
activated with a remote control device, in a manner well known in the art. By 
way of example, a remote control device employing an infrared wave may be 
used. 

Every time a user clicks one of the discrete control functions using a 
mouse or activates one of those functions using a remote control device, that 
action is recorded to a statistics log file stored on a storage device (e.g., hard 
drive) associated with the client computer. By way of example, the log file may 
record a user/player ID, a content ID, the absolute time (AM/PM), and the offset 
from the beginning of the content file to the action (e.g., STOP or PLAY). At the 
end of every session between the client and server computers, the server computer 
queries the client computer as to whether a log file is present- If there is a log file 
present, it is uploaded to the server computer, where it is parsed and placed in the 
database 640 for future analysis. When the log file has been successfully 
uploaded, it is deleted off of the storage device associated with the client 
computer. 

Figure 10 depicts classes of objects stored in the database 640 along with 
their attributes. These classes include a pc_session class 1000, a pcuser class 
1010, a pc_player class 1020, pc_delivery class 1030, a pc_subscription class 
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1040, a pciisent class 1050, a pc_content class 1060, a pc_blurb class 1070, a 
pc_series class 1080, apc_episode class 1085, and a pc_segment class 1090. 

The pc_session class 1000 includes the following attributes: sessionid, 
userid, sessionstamp and active (a status indicator). The pc_user class 1010 
includes the following attributes: userid, loginname, pwd (password), zip and 
lastlogin. The pc_player class 1020 includes the following attributes: playerid, 
userid, datecreated. The pc_delivery class 1030 includes the following attributes: 
deliveryid, playerid, segmentid, contentid, delivered (a status indicator). The 
pc subscription class 1040 includes the following attributes: seriesid, userid, 
datecreated, and datetenninated. The pcjisent class 1050 includes the following 
attributes: listenid, playerid, userid, contentid, segmentid, starttimestamp, 
stoptimestamp, startoffset, and stopoffset. The pc_content class 1060 includes the 
following attributes: contentid, filename, name, active (a status indicator), and 
segmentid. The pc_blurb class 1070 includes the following attributes: blurbid, 
contentid, startoffset, stopoffset, and description. The pcjseries class 1080 
includes the following attributes: active (a status indicator) and name. The 
pc_episode class 1085 includes the following attributes: episodeid, seriesid, name, 
active (a status indicator), sequence, and timecreated. The pcjsegment class 1090 
includes the following attributes: segmentid, episodeid, contentid, sequence, and 
description. 

In addition to those features already mentioned there are additional . 
features that may be associated with the second software module, as set forth 
below. By way of example, the second software module would provide a user of 
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the client computer with the capability to place a media content marker (or 
bookmark) within the content item to mark a place to which they want to return. 
This content marker feature could be implemented using additional control 
functions on the graphical user interface 700. The functions would enable a user 
to create, rename, delete and forward such media content markers. 

An example of another feature of the second software module is that it 
may generate a notification to a user of the client computer upon receipt of a 
media content item. The notification may be an automatic notification, an audio 
notification, or an e-mail, for example, which is sent to the user's e-mail address. 

An example of another feature of the second software module is a locator 
indication feature, which would allow users of the client computer to send to 
anyone via the network an indication (e.g., an e-mail) of a location (i.e., link to a 
URL address) where the media content item may be found. At such a location, a 
recipient of the indicator may find not just media content items, but previews of 
the media content item featured using a media streaming technique. 

An example of yet another feature of the second software module is a 
media content sharing feature, which would allow a user to send a portion or 
segment of a media content item to another individual. By way of example, a 
user could snip out a small segment of the content and attach that media content 
portion or segment directly to an e-mail for distribution to another individual. 
That individual would then be able to play this directly from the e-mail. 

The distribution of media content via the media content sharing feature 
would be controlled using a digital rights management scheme as described 
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below. The digital rights management scheme would take into account a content 
provider's rules on, for example, whether a user will be allowed to make a media 
content segment, how long the segment would be, what the encoding rate would 
be. Because there is great variability in the type of rules applicable to each media 
content item or portion thereof, every piece of content could conceivably have 
different rules attached to it. Thus, the media content sharing feature should be 
implemented in accordance with the digital rights management scheme. 

It is preferable that the system 600 be implemented in accordance with a 
digital rights management scheme to guard against the unauthorized exploitation 
of media content Absent such a scheme, content providers would be reluctant to 
entrust the system 600 with their content Nor would it be prudent for the 
administrator of the system to entrust that content to end-users. Therefore, the 
system 600 should provide safeguards media content cannot be easily duplicated 
or distributed in an unauthorized manner, and ensure that the administrator of the 
system receives compensation for the use of media content items by end users. 
Such safeguards would require encrypting the media content items in such a 
manner that only the users who have paid for the use of the media content items 
may use them. 

A class of software applications known as digital rights management 
systems has been developed to meet the protection requirements of the content 
producers. Digital rights management ensures that only authorized users can use 
a media content item. Furthermore, digital rights management allows for the 
application of very sophisticated rules for the use of this content By way of 
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example, a user may be able to playback a media content item a certain number of 
times for no fee. Thereafter, the user can playback the media content item 
additional times for a particular sum of money. Alternatively, a user may 
purchase the media content item outright for another particular sum. Thus, there 
is a close relationship between digital rights management, e-commerce and 
billing. Examples of digital rights management schemes are featured in U.S. 
Patent No. 6,185,683 and U.S. Patent No. 6,253,193, which are all incorporated 
herein by reference and assigned to Intertrust Technologies Corp. Intertrust 
Technologies Corp. has developed digital rights management software, the 
MetaTrust Utility®, which may be implemented as a digital rights management 
scheme in the system 600 and the components used in the system 600. In 
addition, Microsoft has published a reference, "Digital Rights Management for 
Microsoft Windows Media Technologies", in 2001. Microsoft's Windows Media 
Rights Manager® may also be implemented as a digital rights management 
scheme in the system 600 and the components used in the system 600. Additional 
examples of digital rights management schemes are featured in U.S. Patent No. 
5,530,235; U.S. Patent No. 5,629,980; U.S. Patent No. 5,634,012; U.S. Patent No. 
5,638,443; U.S. Patent No. 6,233,684; and U.S. Patent No. 6,236,971; which are 
all incorporated herein by reference. 

The general trend of the consumer electronics industry is to put data, audio 
and video capabilities on smaller and smaller portable devices, such as personal 
media players. Therefore, the second software module has the capability to 
transfer media files to/from portable devices in accordance with a digital rights 
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management scheme. The second software module may incorporate well-known 
libraries for personal media player support. Another way to transfer media 
content items using the second software module would be to permit users to 
create CD-ROMs containing media content items in accordance with a digital 
rights management scheme. 

A full variety of content purchase transactions may be accommodated 
using the system 600. These transactions include monthly fees for bundles of 
series ("packages"); purchases of individual series ("a la carte"); purchases of 
individual episodes ("pay per view" or 'TPV"). In addition to managing the how 
much content the end user receives, digital rights management also manages how 
long such media content items remain available. For example, a user may have 
access to a particular media content item in perpetuity, or just provide access to a 
particular media content item for a predetermined period of time (e.g., a single 
day). 

The system 600 may implement various advertising schemes. By way of 
example, data, audio and video ads may be placed directly in the media itself, 
much in the same way that television ads are placed between shows. This form of 
media advertising is referred to as an "In-Media Ad". In addition, traditional 
HTML ads (e.g., banners, b-boxes) may be associated with media content items 
and displayed in an additional window pane of the graphical user interface 700. 
These HTML ads could have hotspots which, when clicked using a mouse, would 
take the user to a special promotional page or a third-party vendor's website. 
These are called "Third-Pane Ads". Or a full multimedia advertisement could be 
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delivered as an in-box item, just like a new episode. This form of media 
advertising is referred to as an "Inbox Ad". 

The system 600 may implement a traffic monitoring system that can 
accurately manage this diverse advertising environment. Aggregate behavioral 
statistics collected from users may be used to precisely target ads based on a host 
of parameters such as content item; geographic area; user age; user gender; and 
user income. Thus users may be exposed to different advertising based on their 
behavioral statistics. By way of example, if a user regularly watches a program 
called "Bass Fishing Today", that user may be interested in purchasing some gear 
for a future fishing trip. There are several ways to take advantage of this 
commercial opportunity. By way of example, a simple affiliation relationship 
may exist where a button is provided in an additional windowpane of the 
graphical user interface 700. By clicking on the button using a mouse, a user may 
be transferred to a third-party vendor's web site. Alternatively, system 700 may 
maintain inventory and manages its own e-commerce product clearinghouse. 

Preferably, a user will never have to re-type user information to make a 
purchase from the system. Thus, user data could be exchanged with third-party 
vendors to automatically set up an account for the user. Alternatively, the 
purchased merchandise may be billed to the user's system account 

In addition, each monthly subscription bill sent to a user could be used to 
enable micro-payments. Credit card companies charge two fees for every 
purchase: a fixed per-transaction fee and then a percentage of the transaction 
amount. The fixed fee means that purchases under, for example, ten dollars are 
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pretty expensive. Accordingly, aggregate purchases could be placed on the user's 
monthly subscription bill and then a fee would only have to be paid to a credit 
card company based on the larger amount. 

If a user has chosen to subscribe to a specific media content item or type 
of media content item, there may be other subscribers who enjoy the same media 
content items. The system 600 may provide vehicles for interaction amongst 
users subscribing to similar media content items. Three conventional techniques 
for providing such a vehicle include threaded messaging, instant messaging and 
chat rooms. Threaded messaging, also referred to as bulletin boards, is a virtual 
location where users converse asynchronously via e-mail type messages. 
Typically, a user starts a topic, or "thread" and people respond to that message, or 
respond to the responses thereof. Threaded messaging is useful because the 
messages accumulate, allowing you to read the entire discussion on a particular 
topic. Instant messaging is text-based user-to-user communication, which occurs 
in real-time and does not leave behind a body of messages like threaded 
messaging. Instant messaging is an extremely popular way for users to 
communicate over the network (e.g., Internet). Chat rooms are like instant 
messaging, but it permits group discussions to occur as messages are sent to all 
users in the chat room. The system 600 could also allow users to rate and/or 
recommend content items to others. 

The operation of system 600 will now be discussed. A user opens the 
graphical user interface 700 of the first software playback module 660 on a 
display of the client computer. The user clicks on the Inbox folder 710 using the 
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mouse associated with the client computer and finds at least five new media 
content item have been delivered. The adaptive download module on the server 
computer system has determined that while the user initially registered for a first 
media content item (or type of media content item), the user does not actually 
playback the first media content item often. Thus, only a segment of the first 
media content item has been downloaded. 

The user also subscribes to a particular programming series and one of the 
episodes in that series is included as a second media content item in the Inbox 
folder 710. During the playback of the second media content item, there is a 
review of five different products, as well as five links to the vendors of those 
products that are displayed in a window pane of the graphical user interface 700. 
After hearing the review, the user clicks on one of the links using a mouse and 
goes to that vendor's website to make a purchase. 

A third media content item is included in the Inbox folder 710 and the user 
decides to watch the show by clicking on that media content item. The third 
media content item is an episode of a series featuring a comedian doing a stand-up 
routine. Using the media content sharing feature, the user makes a segment of the 
media content item, which features the best joke of all and sends it to another user 
via e-mail. She also places a media content marker at that point so that the user 
can return to it later. The user may also go to a bulletin board for the third media 
content item and post the user's thoughts about the comedian. The user may also 
receive an instant message from another user regarding the third media content 
item. 
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A fourth media content item containing a news audio program is included 
in the Inbox folder 710. The user decides to listen to the latest installment of the 
news audio program to which the user subscribes. The sponsor for this content 
item knows from the statistical user information gathered for that user, that the 
user is a woman between 35-50 years of age and making between $25,000 to 
$35,000 a year income. The dynamic advertisement insertion feature inserts the 
advertisement that will most likely appeal to Jane. In accordance with a digital 
rights management scheme, the user also has a CD-ROM burned containing the 
fourth media content item using a CD drive associated with the client computer. 
Thus, the fourth media content item is available playback. 

A fifth media content item is also included in the Inbox folder 710. It's a 
pay per view program, which features an interview with an entertainment 
personality and only costs a small fee. Although the small fee would be added to 
Jane's regular monthly bill if the user consumes or plays back the fifth media 
content item, the user is doubtful about the value of the program. Accordingly, 
the user accesses the server computer's website and checks out the comments and 
user ratings section of the website to see what other users have thought about the 
fifth media content item. In addition, the user previews a portion of the fifth 
media content . 
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COMPUTER PROGRAM LISTING 
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#! /usr/local/bin/bash 

if [ $1 3 
then 

echo Dumping everything from the database to $1 
pg_dumpall > $1 
echo Dump completed. 

else 

echo "Usage: db_dutnp_all . sh <filename>" 

fi . 
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# s /usr / local/bin/bash 
if [ $1 ] && [ $2 ] 
then 

echo Creating $1 database from sql file $2 

createdb -U pgsql $1 

psql -U postgres -d $1 < $2 

echo Creation completed. 

else 

echo "Usage: db_create . sh <database> <sql files." 

fi 
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#1 /usr/local/bin/bash 

if [ $1 ] 
then 

echo Dumping everything from the database to $1 
pg^duntpall > $1 
echo Dump completed. 

else 

echo "Usage: db__durap_all . sh <filenarae>" 

fi 
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#! /usr/local/bin/bash 

if [ $1 ] 

then 

echo Dumping the database data to $1 

echo "->Enter pushcast for the username and password." 
pg_dump -a -u pushcast > $1 
echo Dump completed. 

else 

echo "Usage: db_dump_data . sh <filename>" 

fi 
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#! /usr/local/bin/bash 

if [ $1 ] 

then 

echo Dumping the database schema to $1 

echo "->Enter pushcast for the username and password." 

pg_dump -s -u pushcast > $1 

echo Dump completed. 

else 

echo "Usage: db_dump.sh <filename>" 

fi 
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Selected TOC Entries: 
\connect - pushcast 
-- TOC Entry ID 2 (OID 20803) 

Name: pc_user_userid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc_user_userid_seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 3 (OID 20822) 

Name: pc_playerj>layerid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pcjplayer^playerid^seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 4 (OID 20841) 
-- Name: pc_delivery_deliveryid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE ,, pc_delivery_deliveryid_seq n start 1 increment 1 
maxvalue 2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 5 (OID 20860) 

Name: pc_listen_listenid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc_listenJListenid_seq M start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 6 (OID 20898) 

Name: pc_episode_episodeid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc^episode^episodeid^seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 7 (OID 20917) 
« Name: pc_segment_segmentid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc^segment^segmentid^seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 8 (OID 20936) 
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— Name: pc_content_contentid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE n pc_content_contentid_seq n start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 9 (OID 20955) 

Name: pc_blurb_blurbid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE tt pc_blurb_blurbid_seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 10 (OID 20974) 

Name: pc_session_sessionid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc^session^sessionid^seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 11 (OID 20993) 
-- Name: pcj>romo_emailjpromoid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pcj>romo_email_promoid_seq n start 1 increment 1 
maxvalue 2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 12 (OID 21012) 

Name: pc_package_packageid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE ,! pc_package_j)ackageid_seq n start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 13 (OID 21031) 

Name: pc_package_en_package_entry_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc_package_en_package_entry_seq n start 1 increment 1 
maxvalue 2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 15 (OID 21050) 

Name: pc_user Type: TABLE Owner: pushcast 

CREATE TABLE "pc_user n ( 

"userid" integer DEFAULT nextval ( 'pc^user^juserid^seq 1 : : text) NOT 

NULL, 

"loginname" character varying (15) , 
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■pwd- character varying (15) NOT NOLL, 

:Si;iSS« C tSesU with time .one DEFAULT "timestampM ( '2001- 
07-12 ^iT3-05'..-td— t«p- " 'J days- -.interval")), 
" email " character varying (255), 
"sex" character (1) , , 
" income " character varying (255), 
"born" date, § 
"bfname" character varying (255) , 
"blname" character varying (255) , 
"baddll" character varying (255) , 
"baddl2" character varying (255) , 
"bcity" character varying (255) , 
"bstate" character (2) , 
"bzip" character (5) , 
" ccnum" character ( 16 ) , 
"cctype" character varying (255) , 
"expdate" character (5) , 
"seccode" character (3) , 
"sfname" character varying (255) , 
"slname" character varying (255) , 
"saddll" character varying (255) , 
«saddl2" character varying (255) , 
"scity" character varying (255) , 
"sstate" character (2) , 

"szip" character (5) , /n„*^»-4*in 
Constraint "pcuserjpkey" Primary Key ("userxd ) 

) ; 

TOC Entry ID 16 (OID 21106) 
" Name: pc^player Type: TABLE Owner: pushcast 

^^.pSyerSHnSger DEFAULT nextval ( .pc^layerjplaverid_se q . : :text) 
• NOT NULL, 

."^SrS'^Si^ey" Priory Key Cplayerid-, 
) ; 

" TOC Entry ID 17 (OID 21123) 

" Name: pc_delivery Type: TABLE Owner: pushcast 

CREATE TABLE n pc_delivery" ( 

-deliveryid" integer DEFAULT nextval 
(.pc_delivery!deliveryid_seq'::text) NOT NULL, 

"playerid" integer, 
••segment id" integer, 

:S£S££ Smeltamp with time zone DEFAULT 
"^S^nr-pcSiUryjlcey- Primary Key ("deliveryid") 
); 
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TOC Entry ID 18 (OID 21142) 

Name: pc_listen Type: TABLE Owner: pushcast 



CREATE TABLE "pcJListen" ( 

"listenid" integer DEFAULT nextval { , pcJListenJListenid_seq' :: text) 

NOT NULL, 

"playerid" integer, 
"user id" integer, 
"content id" integer, 
"segmentid" integer, 

"starttimestairrp" times tatnp with time zone, 

"stoptimestamp" timestamp with time zone, 

"startoffset" integer, 

"stopoffset" integer, 

"filename" character varying (255) , 

Constraint "pc_listen_j>key" Primary Key ("listenid") 

>; 



TOC Entry ID 19 (OID 21190) 
-- Name: pc_episode Type: TABLE Owner: pushcast 



CREATE TABLE "pc_episode" ( 

"episodeid" integer DEFAULT nextval 
< , pc_episode_episodeid_seq l : :text) NOT NULL, 

"series id" integer NOT NULL, 

"name" character varying (2 55 ) , 

"active" boolean DEFAULT 'f'-^bool NOT NULL, 

"sequence" integer, 

"timecreated" timestamp with time zone DEFAULT 
"timestamp" ( 'now' :: text) , . . x 

Constraint "pc_episode_pkey n Primary Key ("episodeid") 

) ; 



TOC Entry ID 20 (OID 21211) 

Name: pc_segment Type: TABLE Owner: pushcast 



CREATE TABLE "pc_segment" ( 

"segmentid" integer DEFAULT nextval 
( • pc_segment_segment id_seq 1 : : text ) NOT NULL , 

"episodeid" integer, 

"content id" integer, 

"sequence" integer, 

"description" character varying (255) , 

Constraint "pc_segment_pkey" Primary Key ("segmentid") 

); 



TOC Entry ID 21 (OID 21229) 

Name: pc_content Type: TABLE Owner: pushcast 
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CREATE TABLE "pc_content" ( 

"contentid" integer DEFAULT nextval 
(•pc content_contentid_seq'::text) NOT NOLL, 
- " filename" character varying (255) , 

"name" character varying (255) , 

"active" boolean DEFAULT 'f«::bool NOT NULL, 

«url" character varying (255) , 

"mhtml" character varying (255) , .~w,«--n.t±d»l 
constraint "pc_content_pkey» Primary Key ("contentid ) 

) ; 

TOC Entry ID 22 (OID 21249) 
" Name: pc_blurb Type: TABLE Owner: pushcast 

^^.^Si^itS; DEFAULT nextval (.pc.blurb.blurbid.seq.:: text) 

NOT NULL, 

"contentid" integer, 

"startoffset" integer, 

"stopoffset" integer, 

"description" character varying (255) , 

Constraint «pc_blurb_pkey" Primary Key ("blurbid") 

) ; 

-- TOC Entry ID 23 (OID 21267) 

" Name: pc_session Type: TABLE Owner: pushcast 

CREATE TABLE "pc_session" ( 

"sessionid" integer DEFAULT nextval 
( .p C _session_sessionid_seq' : :text) NOT NULL, 

• " ^esSonstaSHimestamp with time zone DEFAULT 

"^^Slve^ooie^DEFADLT <f • . -bool NOT NULL, . 

Constraint °p?_session_pkey" Primary Key ("sessionid") 

); 

TOC Entry ID 24 (OID 21286) 
" Name: pc_promo_email Type: TABLE Owner: pushcast 

CREATE TABLE "pc_promo_email w ( 

-promoid" integer DEFAULT nextval 
( .pc promo email_promoid_seq- : :text) NOT NULL, 

"headerfrom" character varying (255) , 

"headerreplyto" character varying 255) , 

"headersubject" character varying (255) , 

ConJ?ra2f "pc.promo.email^key" Primary Key ("promoid") • 

); 

-- TOC Entry ID 25 (OID 21319) 
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-- Name: pc_package Type: TABLE Owner: pushcast 



CREATE TABLE "pc_package" ( 

"packageid" integer DEFAULT nextval 
('pcjpackagej?ackageid_seq' : :text) NOT NULL, 

"package_type" character varying (255) , 

"description" character varying (255) , 

"icon" character varying (255) , 

Constraint "pc_package_pkey" Primary Key ("packageid") 

>; 



TOC Entry ID. 26 (OID 21335) 

Name: pc_subscription_package Type: TABLE Owner: pushcast 



CREATE TABLE "pc_subscriptionjpackage" ( 
"packageid" integer NOT NULL, 
"user id" integer NOT NULL, 

"datecreated" times tamp with time zone DEFAULT 

"timestamp" ('now' : :text) , 

"dateterminated" timestamp with time zone, 
Constraint "pc_subscriptionjpackage_pkey" Primary Key 

( "packageid" , "userid" ) 

); 



« TOC Entry ID 27 (OID 21352) 

— Name: pc_subscript ion_ser ies Type: TABLE Owner: pushcast 



CREATE TABLE "pc_subscription_series " ( 
"seriesid" integer NOT NULL, 
"userid" integer NOT NULL, 

"datecreated" timestamp with time zone DEFAULT 
"timestamp" ('now 1 : :text) , 

"datetermintated" timestamp with time zone, 

Constraint "pc_subscription_seriesjpkey" Primary Key ("seriesid", 
"userid") 

); • 



TOC Entry ID 28 (OID 21369) 

Name: pcjpackage_entry Type: TABLE Owner: pushcast 



CREATE TABLE "pc_j>ackage_entry" ( 

"packageid" integer NOT NULL, 
"seriesid" integer NOT NULL, 

Constraint "pc_package_entry_pkey" Primary Key ("packageid", 
"seriesid") 
); 



-- TOC Entry ID 14 (OID 21557) 
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~ Name: pc_series_seriesid_seq Type: SEQUENCE Owner: pushcast 

CREATE SEQUENCE "pc_series_seriesid_seq" start 1 increment 1 maxvalue 
2147483647 minvalue 1 cache 1 ; 

TOC Entry ID 29 (OID 21576) 

Name: pc_series Type: TABLE Owner: pushcast 

CREATE TABLE "pc_series" ( 

"seriesid" integer DEFAULT nextval 
(■"pc series seriesid_seq« « : :text) NOT NULL, 

"""active"" boolean DEFAULT 'f'::bool NOT NULL, 

"name" character varying (255) , 

"description" text, 

"adult" boolean, t 

"producer" character varying (255) , 

"start date" date, 

"stopdate" date, m 

"frequency" character varying (255; , 

"episodelength" character varying (255 ) , 

"language" character varying (255) , 

"genre" character varying (255) , 

"icon" character varying (255) , 

Constraint »pc_series_pkey" Primary Key ("senesid") 

); 

-- TOC Entry ID 30 (OID 21637) 

Name: pc.subscription Type: VIEW Owner: pushcast 




UNION SELECT pc subscriPtion_series . series id, 
™ubscription:series.userid FROM pc_subscription_series; 

-- TOC Entry ID 31 (OID 21050) 

Name: «pc_user_loginname_key" Type: INDEX Owner: pushcast 

CREATE UNIQUE INDEX "pc.user JLoginnameJcey" on «pc_user" using btree ( 
"loginname" "varchar_pps" ) ; 

-- TOC Entry ID 32 (OID 21190) 

" Name: «pc_episode_episodeid_keyl" Type: INDEX Owner: pushcast 

CREATE UNIQUE INDEX "pc episode_episodeid_keyl" on "pc episode" using 
"episodeid" "int4_pps«, "name" "varchar.ops" >, 
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TOC Entry ID 33 (OID 21190) 

Name: n pc_episode_episodeid_key2" Type: INDEX Owner: pushcast 



CREATE UNIQUE INDEX "pc_episode_episodeid_key2 " on "pc_ episode" using 
btree ( "episodeid" " int4_ops " , "sequence" "int4_ops" ); 



TOC Entry ID 34 (OID 21408) 
— Name: "RI_ConstraintTrigger_21407" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER DELETE ON "pc_user n NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_del " ( 1 <unnamed> 1 , 1 pc j>layer 1 , 1 pcjiser 1 , 
1 UNSPECIFIED 1 , 1 userid 1 , 1 userid ' ) ; 



TOC Entry ID 35 (OID 21410) 
_- Name: n RI_ConstraintTrigger_21409" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER UPD ATE ON "pc_user" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ,ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_upd" ( ' <unnamed> 1 , 1 pc_player 1 , 1 pc_user 1 , 
■ UNSPECIFIED 1 , ■ userid 1 , 1 userid 1 ) ; 



TOC Entry ID 36 (OID 21412) 

Name: n RI_ConstraintTrigger_21411" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER DELETE ON "pc_user" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_del " ( 1 <unnamed> 1 , 1 pc_listen 1 , 1 pc_user 1 , 
' UNSPECIFIED 1 , 1 userid 1 , 1 userid 1 ) ; 



TOC Entry ID 37 (OID 21414) 

Name: w Rl_ConstraintTrigger_21413" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER " <unnamed> " AFTER UPD ATE ON "pc_user n NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_upd u ( 1 <unnamed> 1 , 1 pc_listen 1 , • peruser 1 , 
' UNSPECIFIED ' , • userid 1 , ■ userid 1 ) ; 



TOC Entry ID 38 (OID 21416) 
— Name: "RI_ConstraintTrigger_21415" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER " <unnaraed> " AFTER DEL ETE ON n pc_user" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
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»RI_FKey_noaction_del" ( ' <unnamed> ' , 'pc_session' , 'pc_user', 
• UNSPECIFIED ' , ' userid ' , ' userid ' ) ; 

-- TOC Entry ID 39 (OID 21418) 

"RI ConstraintTrigger_21417" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER " <unnamed> " AFTER UPDATE ON "P^ser NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_upd" ( ' <unnamed> • , 'pc_session' , 'pc_user , 
' UNSPECIFIED ' , ' userid 1 , 1 userid ' ) ; 

-- TOC Entry ID 40 (OID 21420) 

Name: <'RI_ConstraintTrigger_21419" Type: TRIGGER Owner: pushcast 

pt?eate CONSTRAINT TRIGGER "<unnamed>" AFTER DELETE ON "pc_user" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 

"RI FKey noaction_del " ( ■ <unnamed> « , 'pc_subscription_package , 

'pc~user T , 'UNSPECIFIED', 'userid', 'userid'); 

-- TOC Entry ID 41 (OID 21422) 

-- Name: "RI_ConstraintTrigger_21421" Type: TRIGGER Owner: pushcast 

CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER UPDATE ON "P Causer" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI FKey noaction_upd" ( ' <unnaraed> • , • pc_subscription_j>ackage , 
•peruser 7 , 'UNSPECIFIED' , 'userid', 'userid'); 

— TOC Entry ID 42 (OID 21424) 

Name: "RI_ConstraintTrigger_2l423" Type: TRIGGER Owner: pushcast 

CTREATE CONSTRAINT TRIGGER «<unnamed>" AFTER DELETE ON »pc_user" NOT 
SSr^S'iSt^ALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 

"RI FKey noaction_del" ( ' <unnamed> • , 'pc_subscription_senes , 

■ pc~user T , ' UNSPECIFIED ' , • userid • , ' userid • ) ; 

-- TOC Entry ID 43 (OID 21426) 

-- Name: "RI_ConstraintTrigger_21425" Type: TRIGGER Owner: pushcast 

CREATE CONSTRAINT TRIGGER "<unnamed>» AFTER UPDATE ON «pc_user« NOT 
SSeSaSS TO IALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 

"RI FKey noaction_upd" ( ' <unnamed> ' , 'pc_subscription_senes , 

• pc~user ' , 1 UNSPECIFIED » , ' userid ' , ' userid ' ) ; 

__ TOC Entry ID 44 (OID 21428) 
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Name: "RI ConstraintTrigger_21427" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 
"pcjplayer" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE "RI_FKey_check_ins n ( 1 <unnamed> 1 , ' pc_player 1 , 1 pc_user ' , 
' UNSPECIFIED ' , ' userid 1 , 1 userid 1 ) ; 



-- TOC Entry ID 45 (OID 21430) 

Name: "RI ConstraintTrigger_21429" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER " <unnained> " AFTER DEL ETE ON "pcjplayer" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noact ion_del " ( ' <unnamed> • , 1 pc_delivery 1 , 1 pcjplayer • , 
' UNSPECIFIED ' , 'playerid' , 'player id' ) ; 



TOC Entry ID 46 (OID 21432) 

Name: "RI Cons traintTrigger_2 1431" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER »<unnamed>" AFTER UPD ATE ON "pcjplayer" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI JFKey_noaction_upd" ( 1 <unnamed> 1 , ' pc_delivery ' , 1 pc_player ' , 
' UNSPECIFIED ' , 1 playerid ' , ' playerid 1 ) ; 



TOC Entry ID 47 (OID 21434) 

Name: "RI_ConstraintTrigger_21433" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 

u pc delivery" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE "RI_FKey_check_ins " ( ' <unnamed> ' , ■ pc_delivery 1 , 1 pc_player ■ , 
' UNSPECIFIED ' , ' playerid 1 , 1 playerid ' ) ; 



TOC Entry ID 48 (OID 21436) 

Name: "RI ConstraintTrigger_21435" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 
"pc listen" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE "RI_FKey_check_ins " ( 1 <unnamed> ' , 1 pc_listen ' , 1 pc_listen » , 
' UNSPECIFIED ' , 'playerid' , 1 listenid' ) ; 



-- TOC Entry ID 49 (OID 21438) 

Name: "RI_ConstraintTrigger_21437" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER DEL ETE ON "pcJListen" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
n RI FKey_noaction_del" ( ' <unnamed> 1 , 'pc^listen' , 'pc_listen' , 
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• UNSPECIFIED ' , ' playerid ' , ' listenid ' ) ; 

-- TOC Entry ID 50 (OID 21440) 

Name: "Rl_ConstraintTrigger_21439« Type: TRIGGER Owner: pushcast 

TREATS CONSTRAINT TRIGGER « <unnamed> 11 AFTER UPDATE ON '«pc_listen'< NOT 
S££L£l7 SJtSlS IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
-RI FKey_noaction_upd- <-<unnamed>\ -pc_listen< , 'pc_listen- , 
' UNSPECIFIED * , ' playerid ' , • listenid 1 ) ; 

-- TOC Entry ID 51 (OID 21442) 

" Name: »RI_ConstraintTrigger_21441« Type: TRIGGER Owner: pushcast 

preate CONSTRAINT TRIGGER '<<unnamed>» AFTER INSERT OR UPDATE ON 
SfSsten" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
plocfeSl »Rl!reey_check_ins- < • <unnamed> • , -pc.listen' , -pc.user', 
' UNSPECIFIED 1 , ' userid ' , 1 userid 1 ) ; 

-- TOC Entry ID 52 (OID 21456) 

Name: ''Rl_ConstraintTrigger_21455« Type: TRIGGER Owner: pushcast 

nnwQTWRTwr TRIGGER '• <unnamed> " AFTER INSERT OR UPDATE ON 
^Si-S^OT dIfeSaBLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE »RI_FKey_check_ins« ( ' <unnamed> • , ' pc_e pl sode , •pc.series , 
'UNSPECIFIED', 'seriesid', 'seriesid'); 

-- TOC Entry ID 53 (QID 21458) 

Name: »RI_ConstraintTrigger_21457« Type: TRIGGER Owner: pushcast 

r*EATE CONSTRAINT TRIGGER. «<unnamed>» AFTER DELETE ON "pc_episode« NOT 
SabS "SSLS IMMEDIATE FOR EACH ROW EXECOTE PROCEDURE 

«RI F^y_noaction_del« ( '<unnamed>' , -pc_segment' , 'pc_episode . 

' UNSPECIFIED • , ' episodeid ' , ' episodeid • ) ; 

__ TOC Entry ID 54 (OID 214S0) 

" Name: »RI_ConstraintTrigger_21459« Type: TRIGGER Owner: pushcast 

rp E &TE CONSTRAINT TRIGGER « <unnamed> » AFTER UPDATE ON ''pc_episode«' NOT 
S^STSSLS IMMEDIATE FOR EACH ROW ^JUTE PROCEDURE 
-RI FKey_noactionupd» ( • <unnamed> ' , ' pc_segment ' , 'pc_episode , 
» UNSPECIFIED • , ' episodeid ' , ' episodeid • ) ; 

-- TOC Entry ID 55 (OID 21462) 

" Name: «RI_ConstraintTrigger_21461« Type: TRIGGER Owner: pushcast 
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CREATE CONSTRAINT TRIGGER " <unnamed> " AFTER INSERT OR UPDATE "ON 
"pc segment" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE "RI_FKey_check_ins " ( • <unnamed> 1 , 1 pc_segment 1 , ' pc_episode ' , 
1 UNSPECIFIED • , ' episodeid 1 , 1 episodeid 1 ) ; 



TOC Entry ID 56 (OID 21464) 

Name: "RI ConstraintTrigger_21463 " Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER 11 <unnamed> " AFTER DELETE ON "pc_content " NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RIJFKey__noact ion_del n ( 1 <unnamed> 1 , 1 pc_blurb ■ , 1 pc_content ■ , 
1 UNSPECIFIED 1 , 1 contentid 1 , 1 contentid 1 ) ; 



TOC Entry ID 57 (OID 21466) 

Name: "RI ConstraintTrigger_21465" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnatned>" AFTER UPD ATE ON "p eContent" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI JFKey_noactionjipd M ( 1 <unnamed> 1 , ' pc _blurb 9 , 1 pc_content 1 , 
1 UNSPECIFIED 1 , 1 contentid ■ , 1 contentid 1 ) ; 



-- TOC Entry ID 58 (OID 21468) 

Name: "RI_ConstraintTrigger_21467" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 

"pcjblurb" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE "RI_FKey_check_ins " ( 1 <unnamed> 1 , 1 pc_blurb 1 , ' pc^content 1 , 
* UNSPECIFIED ' , 1 contentid 1 , » contentid 1 ) ; 



TOC Entry ID 59 (OID 21470) 
__ Name: "RI_ConstraintTrigger_21469" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 

"possession" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE 
PROCEDURE n RI_FKey_check_ins " ( ■ <unnamed> 1 , "possession 1 , 'peruser', 
1 UNSPECIFIED 1 , 'userid 1 , 'user id 1 ) ; 



TOC Entry ID 60 (OID 21472) 
-- Name: «RI_ConstraintTrigger_21471" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER DEL ETE ON "pcj>ackage" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noact ion_del " ( 1 <unnamed> ' , 1 pc _package_entry « , » pc_j?ackage 1 , 
1 UNSPECIFIED ' , 1 packageid 1 , 1 packageid ' ) 
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TOC Entry ID 61 (OID 21474) 

Name: »RI_ConstraintTrigger_21473" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER M <unnamed> " AFTER UPDATE ON !, pcj>ackage fl NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKeyjaoaction_upd" ( 1 <unnamed> 1 , 1 pc_package_entry ■ , 1 pc_package 1 , 
' UNSPECIFIED ' , 1 packageid 1 , 1 packageid 1 ) ; 



-- TOC Entry ID 62 (OID 21476) 

-- Name: f! RI_ConstraintTrigger_21475 ,! Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER w <unnamed> n AFTER DELETE ON n pc__package" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_del " ( 1 <unnamed> 1 , ' pc_subscriptionj?ackage 1 , 
1 pc_package 1 , 1 UNSPECIFIED 1 , ' packageid 1 , 1 packageid 1 ) ; 



TOC Entry ID 63 (OID 21478) 

Name: "RI_ConstraintTrigger_21477" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER 11 <unnamed> " AFTER UPDATE ON "pcjpackage" NOT 
DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW EXECUTE PROCEDURE 
"RI_FKey_noaction_upd n ( 1 <unnamed> 1 , 1 pc_subscription_package 1 , 
1 pc_package « , f UNSPECIFIED 1 , 1 packageid 1 , 9 packageid ■ ) ; 



TOC Entry ID 66 (OID 21480) 

Name: »RI_ConstraintTrigger_21479 M Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 
"pc^subscriptionjpackage" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH 
ROW EXECUTE PROCEDURE "RI_FKey_check_ins " ( 1 <unnaraed> 1 , 
1 pc_subscript ion ^package 1 , • pc_package 1 , 1 UNSPECIFIED 1 , 1 packageid 1 , 
packageid' ) ; 



— TOC Entry ID 67 (OID 21482) 

Name: "RI_ConstraintTrigger_21481" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER " <unnamed> " AFTER INSERT OR UPDATE ON 

"pc_subscription_package" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH 

ROW EXECUTE PROCEDURE "RIJ?Key_check_ins" ( ' <unnamed> 1 , 

1 pc_subscript ion_package 1 , 1 pcjiser 1 , 1 UNSPECIFIED 1 , 1 userid ' , 

1 userid ' ) ; 



TOC Entry ID 68 (OID 21484) 
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Name: "RI Cons traintTrigger_2 1483" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER n <unnamed> " AFTER INSERT OR UPDATE ON 
"pc_subscriptionjseries" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH 
ROW EXECUTE PROCEDURE "RIJE^y_check_ins" ( 1 <unnamed> » , 
■pc_subscription_series ' , »pc_series 1 , 1 UNSPECIFIED 1 , 1 seriesid' , 
■seriesid' ) ; 



-- TOC Entry ID 69 (OID 21486) 

Name: "RI Const raintTrigger_2 1485" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 
»pc_subscription_series" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH 
ROW EXECUTE PROCEDURE »RI_FKey_check_ins " ( ' <unnamed> * , 

'pc_subscription_series', /peruser 1 , 'UNSPECIFIED* , 'userid', 'userid'); 



— TOC Entry ID 70 (OID 21488) 

Name: "RI ConstraintTrigger_21487" Type: TRIGGER Owner: pushcast 



CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER INSERT OR UPDATE ON 
«pc_package_entry" FROM «pcj>ackage" NOT DEFERRABLE INITIALLY IMMEDIATE 
FOR EACH ROW EXECUTE PROCEDURE "RIJ?Key_check_ins" ( ' <unnamed> ' , 
' pc _package_entry ■ , • pc_package ■ , « UNSPECIFIED ' , » packageid ' , 
» packageid ' ) ; 

TOC Entry ID 64 (OID 21490) 

Name: "RI_ConstraintTrigger_21489" Type: TRIGGER Owner: pushcast 

CREATE CONSTRAINT TRIGGER "<unnamed>" AFTER DELETE ON "pc_package" FROM 
"pc_package_entry" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW 
EXECUTE PROCEDURE "RI_FKey_noaction_del" ( ' <unnamed> ' , 
'pcjpackage_entry' , 'pc_package " , 'UNSPECIFIED 1 , 'packageid 1 , 
•packageid 1 ) ; 

TOC Entry ID 65 (OID 21492) 
-- Name: "RI_ConstraintTrigger_21491" Type: TRIGGER Owner: pushcast 

CREATE CONSTRAINT TRIGGER " <unnained> " AFTER UPDATE ON "pejpackage" FROM 
«pcj>ackage_entry" NOT DEFERRABLE INITIALLY IMMEDIATE FOR EACH ROW 

EXECUTE PROCEDURE n RI_FKey_noaction_upd" ( 1 <unnamed> ' , 

1 PC jpackage_entry 1 , ' pc_package 1 , • UNSPECIFIED 1 , 1 packageid 1 , 

•packageid 1 ) ; 
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#include "stdafx.h" 
#include "player. h" 
#include "DisplayView.h" 
ftinclude " PlayerDoc . h" 

iinclude "Windowsx.h" // for GET_X_LPARAM 
#include <libxml/tree.h> 
tinclude <algorithm> 
#include "utils.h" 

#ifdef _DEBUG 
#define new DEBUG_NEW 
#undef THIS_FILE 

static char THIS_FILE[] = _FILE_; 
#endif 

IMPLEMENT JDYNCREATE (CDisplayView, CReportView) 

BEGIN MESSAGE_MAP (CDisplayView, CReportView) 
~//((AFX MSG MAP (CDisplayView) 
ON NOTIFY (RVNJETEMRCLICK, 0, OnRclick) 
ON~~ NOTIFY (RVN ITEMCLICK, 0, OnClick) 
ON~~ COMMAND (ID~DISPLAY_DELETE, OnDeleteMedia) 
ON~COMMAND ( IDJ3ISPDAY_PLAY , OnPlayMedia) 
ON~NOTIFY (RVN ITEMDBCLICK, 0, OnDblclk) 
ON"NOTIFY(RVN~HEADERCLICK / 0, OnColumnClick) 
ON NOTIFY RVN~ITEMCALLBACK, 0, OnRvnltemCallback) 

OnUpdateViewAlternateColors) 

ON_COMMAND(ID_DELETE, OnDeleteMedia) 

//}}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

CDisplayView : : CDisplayView ( ) { 

m_iSelected = RVI_INVALID; 

/// ,/n!/////n/u/i/u////nnm/iu/iiniufiun//titn/u/iuuiu/ 
inn . a . 

II CDisplayView drawing 

void CDisplayView: :OnDraw (CDC* pDC) 

^ CDocument* pDoc - GetDocument () ; 
// TODO: add draw code here 

luunuiu/u/u/nu/n/n/i/i/iunni/u/u/uiun/u/u/i/uum 

//^CDisplayView diagnostics 
#ifdef DEBUG 

void CDisplayView: :AssertValid() const 



77 



WO 03/010634 



PCTAJS02/23713 



^ CReportView: :AssertValid() ; 

} 

void CDisplayView: :Dump (CDumpContext& dc) const 

CReportView: :Dump (dc) ; 
jfendif //_DEBUG 

/// 1 in 1 1 ii iiiii i iimmi 1 1 ii i ii iiiiiiiiiiiiiiiiiiiiiii ilium mi a a 
11111 

II CDisplayView message handlers 
void CDisplayView: :OnInitialUpdate {) 
! CReportView : : OnlnitialUpdate ( ) ; 

/* -— 

-BEGIN- Add columns to the list view. 

*/ 

RVSUBITEM rvs; 

rvs.lpszText = JT ("Show") ; 
rvs.iWidth =170; 

GetReportCtrl ( ) . Def ineSubltem ( 0 , &rvs ) ; 
GetReportCtrl () .ActivateSubltem (0, 0) ; 

/★rvs.lpszText = _T ( "Episode" ) ; 
rvs-iWidth = 50; 

GetReportCtrl () .Def ineSubltem (1, &rvs) ; 
GetReportCtrl 0 .ActivateSubltem (1, 1) ;*/ 

rvs . IpszText' = _T( "Description") ; 
rvs.iWidth = 240; 

GetReportCtrl ( ) . Def ineSubl tem ( 1 , &rvs ) ; 
GetReportCtrl ( ) . ActivateSubltem ( 1 , 1) ; 

rvs.lpszText = _T ( "Received" ) ; 
rvs.iWidth = 140; 

GetReportCtrl 0 -Def ineSubltem (2, &rvs) ; 
GetReportCtrl ( ) . ActivateSubltem (2 , 2 ) ; 

/* Published used to be here */ 

rvs.lpszText = _T("Days To Trash"); 
rvs.iWidth = 100; 

GetReportCtrl () -Def ineSubltem (3, &rvs) ; 
GetReportCtrl ( ) . ActivateSubltem (3,3); 

/*— 

-END- Add columns to the list view. 
*/ 

/* 

-BEGIN- Use Transparency 

*/ 

/*WCEAR wszWallpaper [MAX_PATH] ; 
CSt ring strPath; 
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HRESULT hr; 
IActiveDesktop* pIAD; 

// l. Initialize the COM library (make Windows . load the DLLs). 
Normally you would call m __ 

// this in your Initlnstance ( ) or other startup code. In MFC apps, 

use AfxOlelnit () instead. 
Colnitialize ( NULL ) ; 

1/2. Create a COM object, using the Active Desktop coclass provided 
by the shell. 

// The 4th parameter tells COM what interface we want 
(IActiveDesktop) . 

hr = CoCreatelnstance ( CLSID_ActiveDesktop, 

NULL, 

CLSCTX_INPROC_SERVER , 
IID_IActiveDesktop , 
(void**) &pIAD ) ; 

if ( SUCCEEDED (hr) ) 

// 3. If the COM object was created, call its GetWallpaper () 
method. ^ ^ pIA i>->GetWallpaper ( wszWallpaper, MAX_PATH, 0 ) ; 

if ( SUCCEEDED (hr) ) 

// 4. If GetWallpaper () succeeded, print the filename it 
returned. ^ ^ ^ us i n g wcout to display the Unicode string 

wszWallpaper. wcout is 

// the Unicode equivalent of cout. 

CString sWallpaper = wszWallpaper; * 
GetReportCtrlO .SetBklmage (sWallpaper) ; 

} 

else 

s 

// 5. Release the interface. 
pIAD->Release () ; 

} 

else 

s 

II 6. Uninit the COM library. In MFC apps, this is not necessary 
since MFC does it for us. 
CoUninitialize () ; 

*//* 

-END- Use Transparency 

1 */ 

m_oleDropTarget . Register ( this ) ; 

} 

BOOL CDisplayView::PreCreateWindow(CREATESTRUCT& cs) 
^ cs. style |= RVS_OWNERDATA; 

GetReportCtrl ( ) . InsertColor ( 0 , 0X00C0D8C0 ) ; 

GetReportCtrl () . InsertColor (1, : :GetSysColor ( COLOR JS*AYTEXT) ) ; 
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GetReportCtrl () . InsertColor (2 , OxOODOCOCO) ; 
GetReportCtrlO -InsertColor (3, 0x00804000) ; 

//We need read too 

GetReportCtrl () . InsertColor (4 , 0x0 00 00 OFF) ; 
return CReportView : : PreCreateWindow ( cs ) ; 

} 

void CDisplayView: :OnUpdate (CView* pSender, LPARAM lHint, CObject* 
pHint) 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument 0 ) ; 
if (pDoc->GetCurSelectedFolder 0 != NULL) { 

GetReportCtrl () .DeleteAllItems () ; 

AddMediaFromXML (pDoc->GetCurSelectedFolder ( ) ) ; 

} 

} 

void CDisplayView: -.AddMediaFromXML (xmlNodePtr node) 

^ // Remember the working folder node 

currentFolderNode = node; 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 
// Setup the proper columns- . .ie # the inbox and trash need Days to 

Purge 

SetupColutnns ( ) ; 

// Purge any item 
/ / pDoc- >purgel terns (node) ; 

// Clear current item data from previous folder. 
currentltemData . clear ( ) ; 

// Set item data for current folder. 

f or (xmlNodePtr item = node->children; item != NULL; item = item-> 
next) { 

if (strcmp(reinterpret_cast<const char *> (item->name) , 
"Media") ==0) { 

currentltemData . pushjback ( item) ; 

} 

} 

// Configure the list widget. 
GetReportCtrlO . FlushCache ( ) ; 

GetReportCtrl () . SetltemCount (currentltemData. size () ) ; 

} 

void CDisplayView: :OnRclick(NMHDR* pNMHDR, LRESULT* pResult) 

^ CReportCtrl & 1c - GetReportCtrlO; 

/* Get the mouse cursor position */ 
DWORD dwPos = GetMessagePos () ; 

/* Convert the co-ords into a CPoint structure */ 

CPoint pt( GET_X__LPARAM ( dwPos ), GET_Y_LPARAM ( dwPos ) )/ spt; 

spt = pt; 

/* Convert to screen co-ords for hittesting */ 
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lc.ScreenToClient( &spt ); „ M# a e it- in the future 

// Set rightClickPoint incase someone needs it in tne xuu 

// for hittesting. 
rightClickPoint = spt; 
// Add Popup menu 

CMenu menu; % 
VERIFY (menu . LoadMenu ( IDR_DISPLAY MENU) ) ; 
CMenu* pPopup = menu.GetSubMenu(O) ; 
• ASSERT (pPopup ! = NULL) ; 
pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM.RIGHTBUTTON , pt.X, 
p t . y , Af xGetMainWnd ( ) ) ; 
*pResult = 0; 

// Purpose: Delete the selected item. If item is in the trash and not 
// Cal ' delete it from the drive, otherwise remove the 

xmlnode. M ' 

void CDisplayView : : OnDeleteMedia [ ) 

CReportCtrl &lc = GetReportCtrl () ; 

// Get the position of the first selected item, 
int pos = lc.GetFirstSelectedltemO; 

// If something is selected, do" the following. • 

if (pos) { 

while (pos) { 

// Get the selected item, 
int nltem = lc.GetNextSelectedltem(pos) ; 
TRACE1 ( " Item %d was selected 1 \n" , nltem); . ri . om s . 

• SodePtr node = (xmlNodePtr) Ic^GetltemData (nltem) , 
xmlNodePtr node = current ItemData [pos] ; 

//• Check if item is in the trash. 

if (pDoc->InTrash()) { 1npal 
V * // pile is in trash so check if not local, 
■wnichar *show = xmlGetf>rop (node , 
xmicnar reinterpret _ cast<COIls t unsigned char 

*> ("SHOW")); gtring strShow = re interpret_cast<const char *> 

(show); if (« (strShow == "Local")) { 

//File was not local so delete from drive. 
xmlChar *url = xmlGetProp (node , 

reinterpret_cast<const 

unsigned char *> ("URL") ) ; atxiog gtrURL = reinterpr et_cast<const 

char *> (url) ; ±£ ( , DeleteFi ie (strURL. c_str 0 ) ) 

MessageBox("File not 

deleted . " , NULL , MBJDK) ; 

// File was not in trash so move it there. 
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} 



} else { 

pDoc->MoveNodeToFolderNode (node, NULL); 

} 

// Delete node from list and xml . 
//lc.Deleteltem(nltem) ; 

current I temData. erase (currentltemData .begin ( ) +pos) ; 
lc . FlushCache ( ) ; 

1c . SetltemCount (currentltemData . size ( ) ) ; 
lc . Invalidate ( ) ; 
xmlUnlinkNode (node) ; 

// Get the next selected item if there is one. 
//pos = lc.GetFirstSelectedltemO ; 
pos = false; 

} 

// Otherwise no items were selected. 
} else { 

TRACEO ( "No items were selected I \n n ) ; 

} 



// Opens the media that is double clicked by sending a message to the 
MainFrame . 

void CDisplayView: : OnDblclk (NMHDR* pNMHDR, LRESULT* pResult) 

: : PostMessage (GetParentFrame ( ) - >m_hWnd , WM_USER_PLAY , (WPARAM) 0 , 
(LPARAM)O); 

*pResult = 0; 

} 

bool CDisplayView: : SetupColumns () 

{ 

if (GetReportCtrl ( ) . GetActiveSubltemCount ( ) ) { 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocuraent () ) ; 
CHeaderCtrl* headCtrl = GetReportCtrl () .GetHeaderCtrl () ; 
. /* Should trash purge itself ?. .Should they Ktiow? */ 
//if (pDoc->InInbox() || pDoc->InTrash() ) { 
if (pDoc - >InInbox ( ) ) { 

if ( ! GetReportCtrl ( ) . IsAct iveSubltem ( 3 ) ) { 

GetReportCtrl ( ) • Act ivateSubl tern (3 , 3 ) ; 
return true; 

else { 

return true; 

, 1 

else { 

if (GetReportCtrl ( ) . IsActiveSubltem (3 ) ) { 

GetReportCtrl ( ) .DeactivateSubltera (3 ) ; 
return true; 

else { 

return true; 

} 



return true; 



82 



WO 03/010634 



PCT/US02/23713 



} 

void CDisplayView: : OnClick (NMHDR* pNMHDR, LRESULT* pResult) 

1 /• 

-BEGIN- Find the Item Clicked on 

*/ 

/* Get the mouse cursor position */ 
DWORD dwPos = GetMessagePos () ; 

/* Convert the co-ords into a CPoint structure */ 

CPoint pt( GET_X_LPARAM( dwPos ), GET_Y__LPARAM ( dwPos ) ), spt; 

spt = pt; 

/* Convert to screen co-ords for hittesting */ 
GetReportCtrl 0 .ScreenToClient ( &spt ); 

RVHITTESTINFO hti; 

hti. point = spt; , ^ 

int selectedltem = GetReportCtrl () .HitTest (&hti) ; 
if (selectedltem < 0) return; 

/* 

. -END- Find the Item Clicked on ^ 



-BEGIN- drag-and-drop ^ 

typedef struct { xmlNodePtr x; } S; 

HANDLE hData = : :GlobalAlloc (GMEM_MOVEABLE , sizeof (S) ) ; 
S* s = (S*) ::GlobalLock (hData); 

s->x = xmlCopyNode (current I temData [selectedltem] ,1) ; 
: -.GlobalUnlock (hData) ; 

SS? D S^t C = (tckayerapp*) AfxGetApp 0 ) ^GetClipboardFormat 

0 * 

ods.CacheGlobalData (nFormat, hData); 
int nOldSel = selectedltem; 

DROPEFFECT de = ods . DoDragDr op (DROPEFFECT_COPY | 
DROPEFFECT_MOVE) ; 

if (de == DROPEFFECTJVIOVE) { _ . 

xmlUnlinkNode( current ItemData [selectedltem] ) ; 
xmlFreeNode (current ItemData [selectedltem] ) ; , . 

current I temData. erase (current I temData, begin () +selectedltem) , 
GetReportCtrl () . SetltemCount (currentltemData.size () ) ; 
CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> 

(GetDocument.O ) ; 

pDoc->UpdateAllViews (NULL) ; 

} 

xmlFreeNode (s->x) ; 
: :GlobalFree (hData) ; 

/* - 

-END- drag-and-drop ± j 

} 

void CDisplayView: :OnColumnClick(NMHDR* pNMHDR, LRESULT* pResult) 
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LPNMRVHEADER Ipnmrv = ( LPNMRVHEADER) pNMHDR ; 

switch ( Ipnmrv- >iSubI tern) { 
case 0: { // Show 

std : : sort ( current I temData .begin ( ) , currentltetnData . end ( ) , 

SShowSort ( ) ) ; 

break; 

} 

case 1: { // Episode 

std : : sort (currentlteraData . begin ( ) , currentltetnData . end ( ) , 

SEpisodeSort () ) ; 

break; 

case 2: { // Description 

std : : sort (currentltetnData . begin { ) , currentltetnData . end ( ) , 
SDescriptionSort () ) ; 

break; 

case 3: { // Received 

std : : sort ( currentltetnData . begin ( ) , currentltetnData . end ( ) , 

SReceivedSort () ) ; 

break; 

} 

case 4: { // Published 

std : : sort (currentltetnData . begin ( ) , currentltetnData . end ( ) , 
SPublishedSort () ) ; 

break; 

} 

case Si { II Days To Purge 

std: :sort (currentltetnData. begin () , currentltetnData . end ( ) , 

SDaysToPurgeSort ( ) ) ; 

break ; 



GetReportCtrl () .FlushCache () ; 
GetReportCtrl ( ) . Invalidate ( ) ; 

*pResult =0; 

} 

void CDisplayView: sOnRvnltemCallback (NMHDR *pNMHDR, LRESULT *pResult) 

* /* Based on Figure 10-9 page 602, "Prograitrming Windows with MFC 

2nd Ed." by Jeff Prosise */ 

LPNMRVITEMCALLBACK lpnmrvic = (LPNMRVTTEMCALLBACK) pNMHDR; 

int daystopurge = 1; # 
xmlNodePtr item = currentltetnData [lpnmrvic ->item. litem] ; 
if ((item NULL) || (lpnmrvic->item. iltem < 0)) return ; 

switch (lpnmrvic->item. iSubltem) { 
case 0: { // Show 

• xmlChar *show = xmlGet Prop (item, 

reinterpret_cast<const unsigned char *> ("SHOW") ) ; 
string strShow = reinterpret_cast<const char *>(show); 

_tcscpy (lpnmrvic->item.lpszText, strShow.c_str () ) ; 
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break; 

} . " 

/♦case 1: { // Episode 

xmlChar *episode = xmlGetPropdtem, mwronrm-n • 

reinterpret cast«=onst unsigned char *> ( "EPISODE" ) ) ; 
string strEpisode"= reinterpret_cast<const char *> (episode); 

_tcscpy ( lpnrarvic - >item . IpszText , strEpisode . c_str ( ) ) ; 
break; 

}*/ 

case 1: { // Description 

xtnlChar *desc = xmlGetProp(item, .„„„„,,. 

reinterpret cast <const unsigned char *>(»DESC»)); 
string strDesc = reinterpret_cast<const char *> (desc) ; 

_tcscpy (lpnmrvic->item. IpszText, strDesc . c_str 0 ) ; 
break; 

} 

case 2: { // Received 

xmlChar *received = xmlGetProp(item, * •> ( « received " ) ) • 

reinterpret_cast<const unsigned char *> ( "RECEIVED )), 
string strReceived = reinterpret_cast<const char *> 

(received) ; 

_tcscpy(lpnmrvic->item. IpszText, strReceived. c_str 0 ) ; 
break; 

} 

case 3- i II Days to Purge 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> 

(GetDocument 0 ) ; 

daystopurge = 1; 

xmlChar deceived = xmlGetProp (item, ..received") ) • 

reinterpret_cast<const unsigned char *>( "RECEIVED )), 
string strReceived = reinterpret_cast<const char *> 



(received) 
"-")) { 



if ((pDoc->minbox() || P Doc->InTrash() ) && (strReceived ! = 
char strDays [255] ; 
crime recvCTime = CUtils : :BuildCTime (strReceived. c_str 

() ) '" CTime curCTime = CTime: :GetCurrentTirae () ; 

CTimeSpan elapsedTime = curCTime. - recvCTime; 
daystopurge = pDoc->GetDaysToPurgeInbox() - 

ela P sedTime.GetDays^; ntf(strDays< ^ daystopurge) ; 

_tcscpy(lpnmrvic->item. IpszText, strDays) ; 

} 

break; • 

} 

} // end switch 

/* - 
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-BEGIN- Mark unheard as bold 

*/ 

xmlChar *listened = xmlGetProp (item, 

reinterpret_cast<const unsigned char *>■( "LISTENED") ) ; 
string strListened = "0"; 
if (listened != NULL) 

strListened = re interpret_cast< const char *> (listened) ; 
if (strListened == "0") { 

lpnmrvic->item.nMask |= RVIM_STATE; 

lpnmrvic->item.nState | = RVISJ30LD; 

} 

/* 

-END- Mark unheard as bold 

*/ 

/* 

-BEGIN- Mark read if soon to be purged 

*/ 

// Setup RED as a color we can set items too. 

if (daystopurge <= 0) { // draw as red 
lpnmrvic->item.iTextColor = 4; 
lpnmrvic->item.nMask |= RVIM__TEXTCOLOR; 
tcscpydpnmrvic-^tem.lpszText, "Will Be Purged"); 

} 



-END- Mark read if soon to be purged 
*/ 



if (lpnmrvic->itenuiltem == m_iSelected) 

^ lpnmrvic->item.nMask |= RVIM_STATE; 

lpnmrvic->item.nState |= RVTS_SELECTED ; 

} 

pResult ■ FALSE; 

} 

void CDisplayView: :OnRvnSelectionChanged(NMHDR* pNMHDR, LRESULT* 
pResult) 

^ LPNMREPORTVTEW Ipnmrv = (LPNMREPORTVIEW) pNMHDR; 

if ( Ipnmrv- >nState&RVIS_S ELECTED) { 

// Get the data for the current item. 

xmlNodePtr item = current ItemData [Ipnmrv- >iltem] ; 

if (item != NULL) { 

// Set the current item in the document. 
CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> 

(GetDocument ( ) ) ; 

pDoc->SetCurSelectedItem(item) ; 
: :PostMessage (this->GetParentFrame 0 -> 
m hWnd,WM USER LOADURL, (WPARAM)O, (LPARAM)O) ; 
~ }~ 

m_iSelected = Ipnmrv- >iltem; 

} 
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pResult = FALSE; 

} 

bool sshowSort: : operator () (xmlNodePtrfc iteml, xmlNodePtrfc item2) 

xmlChar *showl = xmlGetProp (iteml, , 

reinterpret_cast<const unsigned char *>("SHOW )), 
string strShowl = reinterpret_cast<const char *>(showl); 

xmlChar *show2 = xmlGetProp (it em2, ,„.„„„,,. 

reinterpret_cast<const unsigned char *> ("SHOW") lu- 
string strShow2 = reinterpret_cast<const char *>(show2); 

return - (CUtils:: cmp_nocase{ strShowl, strShow2) < 0) ? true : false; 

} 

bool SEpisodeSort: : operator () (xmlNodePtr* iteml, xmlNodePtr& item2) 

* • xmlChar *episodel = xmlGetProp (iteml, ,„ OTsnn r»n. 

reinterpret cast<const unsigned char *> (••EPISODE-;) ) , 
string strEpisodel = reinterpret_cast<const char *> (episodel) ; 

xmlChar *episode2 = xmlGetProp (item2, ^eptsodE") )•• 

reinterpret cast<const unsigned char *> ("EPISODE )), 
string strEpisodel = reinterpret_cast<const char *> (episode2) ; 

return (CUtils: :cmp_nocase (strEpisodel, strEpisode2) < 0) ? true : 

• false; 
} 

bool SDescriptionSort: : operator 0 (xmlNodePtrJc iteml, xmlNodePtrfc item2) 

xmlChar *descl = xmlGetProp (iteml, 

reinterpret_cast<const unsigned char *> (."DESC") > ; 
string strDescl = reinterpret_cast<const char *> (descl) ; 

xmlChar *desc2 * xmlGetProp (item2, 

reinterpret cast<const unsigned char *>("DESC")); 
string strDesc2 = reinterpret_cast<const char *>(desc2); 

return (CUtils : :cmp_nocase (strDescl, strDesc2) < 0) ? true : false; 

} 

bool SReceivedSort: : operator () (xmlNodePtrfc iteml, xmlNodePtrfc item2) 

xmlChar *receivedl = xmlGetProp (iteml , „ RBCE tveD" ) ) • 

reinterpret cast<const unsigned char *>( "RECEIVED )), 
string SSSivedl = reinterpret_cast<const char *> (receivedl) ; 

xmlChar *received2 = xmlGetProp (item2, «p PCE TVED« ) ) • 

reinterpret cast<const unsigned char *>( "RECEIVED )), 
string sSReclived2 = reinterpret_cast<const char *> (received2) ; 

if (strReceivedl == "-" strReceived2 =="-") { 
return false; 

if (strReceivedl == "-" strReceived2 != "-") { 
return true; 

if (strReceivedl != "-" && strReceived2 == "-") { 
return false; 
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} 

CTime curCTime = CTime: :GetCurrentTime () ; 

CTime recvCTimel « CUtils: :BuildCTirae (strReceivedl .c_str () ) ; 
CTime recvCTime2 = CUtils : : BuildCTime ( strReceived2 . c_str ( ) ) ; 
CTimeSpan ts = recvCTimel - recvCTime2; 

return (ts.GetTotalSeconds () < 0) ? true : false; 



bool SPublishedSort: : operator () (xmlNodePtrfc iteml, xmlNodePtrfc item2) 

^ xmlChar *publishedl = xmlGetProp (iteml, 

reinterpret_cast<const unsigned char *> ("PUBLISHED") ) ; 
string strPublishedl = reinterpret_cast<const char *> (publishedl) ; 

xmlChar *published2 = xmlGetProp (item2 , 

reinterpret_cast<const unsigned char *> ("PUBLISHED") ) ; 
string strPublished2 = reinterpret_cast<const char *> (published2) ; 

if (strPublishedl p== && strPublished2 == "-") { 
return false; 

if (strPublishedl == "-" && strPublished2 !="-") { 
return true; 

if (strPublishedl != "-" && strPublished2 =="-") { 
return false; 

} 

CTime pubCTimel ■ CUtils :: BuildCTime (strPublishedl. c_str() ) ; 
CTime pubCTime2 = CUtils : :BuildCTime (strPublished2 .c_str() ) ; 
CTimeSpan ts = pubCTimel - pubCTime2; 

return (ts.GetTotalSeconds () < 0) ? true : false; 



bool SDaysToPurgeSort :: operator () (xmlNodePtrfit iteml, xmlNodePtrfc item2) 

^ xmlChar *receivedl = xmlGetProp (iteml, 

reinterpret_cast<const unsigned char *> ("RECEIVED") ) ; 
string strReceivedl = reinterpret_cast<const char *> (receivedl) ; 

xmlChar *received2 = xmlGetProp ( item2 , 

reinterpret_cast<const unsigned char *> ("RECEIVED") ) ; 
string strReceived2 = reinterpret_cast<const char *> (received2) ; 

if (strReceivedl == "-" && strReceived2 =="-") { 
return false; 

if (strReceivedl « "-" && strReceived2 != "-") { 
return true; 

if (strReceivedl != "-" && strReceived2 == ■-") { 
return false; 

} 

CTime curCTime = CTime: : GetCurrentTime () ; 

CTime recvCTimel = CUtils : : BuildCTime (strReceivedl . c_str ( ) ) ; 
CTime recvCTime2 = CUtils :: BuildCTime (strReceived2 .c_str() ) ; 
CTimeSpan elapsedTimel = curCTime - recvCTimel; 
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CTimeSpan elapsedTime2 = curCTime - recvCTime2; 
int daystopurgel = 

elapsedTimel.GetDays 0 ; 
int daystopurge2 = 

elapsedTime2 .GetDays () ; 

return ((daystopurgel - daystopurge2 ) < 0) ? true : false; 

} 

void CDisplayView : : OnViewShowVGrid ( ) 

CReportCtrlfc rc = GetReportCtrl () ; 
if (rc •GetStyle 0 &RVS_SHOWVGRID) 

rc . Modif yS ty le <RVS_SHOWVGRID , 0 ) ; 

else 

r c . Modif yStyle ( 0 , RVS JSHOWVGRID) ; 

} 

void CDisplayView: :OnUpdateViewShowVGrid(CCmdUI* pCmdUI) 

^ CReportCtrlfc rc « GetReportCtrl () ; 

pCmdUI->SetCheck(rc.GetStyle() &RVS_SHOWVGRID) ; 

} 

void CDisplayView : : OnViewShowHGrid ( ) 

^ CReportCtrlfc rc = GetReportCtrl ( ) ; 

if (rc . GetStyle () &RVS_SHOWHGRID) 

rc . Modif yStyle (RVS_SHOWHGRID , 0 ) ; 

else 

rc . Modif yStyle ( 0 , RVS_SHOWHGRID) ; 

} 

void CDisplayView: :OnUpdateViewShowHGrid(CCradUI* pCmdUI) 

CReportCtrlfc rc = GetReportCtr 1 ( ) ; 

pCmdUI- >SetCheck (rc . GetStyle ( ) &RVS_SHOWHGRID) ; 

} • 

void CDisplayView: :OnViewShowHGridEx() 

CReportCtrlfc rc * GetReportCtrl () ; 
if (rc - GetStyle ( ) &RVS_SHOWHGRIDEX) 

rc . Modif yStyle (RVS_SHOWHGRIDEX , 0 ) ; . 

else 

rc . Modif yStyle ( 0 , RVS_SHOWHGRID | RVS_SHOWHGRIDEX) ; 

} 

void CDisplayView: :OnUpdateViewShowHGridEx(CCradUI* pCmdUI) 

^ CReportCtrlfc rc = GetReportCtrl () ; 

pCmdUI->SetCheck(rc.GetStyle() &RVS_SHOWEGRIDEX) ; 

} 

void CDisplayView: :OnViewAlternateColors () 

' CReportCtrlfc rc = GetReportCtrl 0 ; 

if (rc . GetStyle ( ) &RVS_SHOWC0LORALTERNATE) 

rc . ModifyStyle (RVSJ3HOWCOLORALTERNATE , 0 ) ; 

elSS rc.ModifyStyletO, RVS_SHOWCOLORALTERNATE) ; 
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} 

void CDisplayView: :OnUpdateViewAlternateColors (CCmdUI* pCmdUI) 
CReportCtrl& rc = GetReportCtrl ( ) ; 

pCmdUI - >SetCheck (rc . GetStyle ( ) &IVS JSHOWCOLORALTERNATE ) ; 

yoid CDisplayView: :OnNmReturn(NMHDR* pNMHDR, LRESULT* pResult) 

LPNMREPORTVTEW lpnmrv = (LPNMREPORTVIEW) pNMHDR; 
if ( lpnmrv - >nKeys == VK_RETURN) { 

: :PostMessage(GetParentPrame{) ->m_hWnd,WM USER PLAY, (WPARAM) 
0, (LPARAM)O); ~ ~ 

*pResult = 0; 

DROPEFFECT CDisplayView: :OnDragEnter (COleDataObject* pDataObject, 
DWORD dwKeyState, CPoint point) 



{ 



} 



CReportView: :OnDragEnter (pDataObject, dwKeyState, point); 

if (pDataObject->IsDataAvailable (CF_HDROP) ) { 
// Only Copy allowed on filenames 
return DROPEFFECT_COPY; 

else 

return DROPEFFECT_NONE ; 



DROPEFFECT CDisplayView: :OnDragOver (COleDataObject* pDataObject, 
DWORD dwKeyState, CPoint point) 

CReport View : : OnDragOver (pDataOb j ect , qtwKeyStat e , point ) ; 

if (pDataObject->IsDataAvailable (CF_HDROP) ) { 
// Only Copy allowed on filenames 
return DROPEFFECT_COPY; 

else 

return DROPEFFECT_NONE ; 

BOOL CDisplayView: :OnDrop (COleDataObject* pDataObject, DROPEFFECT 
dropEf f ect , 

CPoint point) 

CReportView: :OnDrop (pDataObject, dropEf feet, point) ; 

// See if filenames are on the clipboard. 
HDROP hDrop = (HDROP) pDataObject->GetGlobalData (CF_HDROP) ; 
if (hDrop ! = NULL) { 

// Find out how many file names the HDROP contains, 
int nCount = : :DragQueryFile (hDrop, (UINT) -1, NULL, 0); 
// Enumerate the file names, 
if (nCount) { 

TCHAR szFile [MAX_PATH] ; 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> 
(GetDocument () ) ; 
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for (int i=0; i<nCount; i++) { 

: :DragQueryFile (hDrop, i/szFile, 
sizeof (szFile) / sizeof (TdHAR) ) ; 

pDoc->AddMediaToXML ( current FolderNode, 

szFile, 



CUtils : :get_currdatetime () , 
} 

^ pDoc->UpdateAllViews (NULL) ; 

: :GlobalFree (hDrop) ; 
return TRUE; // Drop succeeded - 



} 

return FALSE; 



"Local ", 

n _ 11 

i 

szFile, 



n _ n 

"local", 
"none") ; 



// Drop failed!. 



void CDisplayView : : OnPlayMedia ( ) 



{ 



: :PostMessage ( Af xGetMainWnd ( ) - >mJhWnd / WM_USER_PLAY , 0 , 0) ; 
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#if ! defined (AFXJDISPLAYVIEW_H_A7AFBE0C_5E5C_4EC4_88C5_853C27172BF5 
INCLUDED ) 

Idefine AFX_DISPLAYVIEW_H_A7AFBE0C_5E5C_4EC4_88C5 - 853C27172BF5 
INCLUDED^ 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

#include <libxml/tree.h> 
#include <string> 
#include <vector> 
#include <afxole.h> 
#include "ReportCtrl.h" 



class CDisplayView : public CReportView 

{• 

protected: , 

DE CLARE_p YNCREATE (CDisplayView) 

// Attributes 
public : 

CDisplayView () ; 
// Operations 
public : 

void AddMediaFrotriXML (xmlNodePtr node) ; 
// Overrides 

// ClassWizard generated virtual function overrides 

// { {AFX_VIRTUAL (CDisplayView) 

public: 

virtual void OnlnitialUpdate ( ) ; 
protected : 

virtual void OnDraw(CDC* pDC) ; // overridden to draw this 

view 

virtual BOOL preCreateWindow (CREATESTRUCT& cs) ; 
virtual void OnUpdate (CView* pSender, LPARAM lHint, CObject* 
pHint) ; 

virtual DROPEFFECT OnDragEnter (COleDataObject* pDataObject, DWORD 
dwKeyState, CPoint point); 

virtual DROPEFFECT OnDragOver (COleDataObject* pDataOb3ect, DWORD 
dwKeyState, CPoint point) ; 

virtual BOOL OnDrop( COleDataObject* pDataObject, DROPEFFECT 
dropEffect, CPoint point) ; 
//}}AFX_VIRTUAL 

// Implementation 
protected: 
#ifdef _DEBUG 

virtual void AssertValidO const; 

virtual void Dump (CDurapContextfc dc) const; 

#endif 

// Generated message map functions 
protected : 

COleDropTarget m_oleDropTarget; 

CPoint rigbtClickPoint; 

bool SetupColumns () ; 

//{ {AFXJ4SG (CDisplayView) 

afxjnsg void OnRclick (NMHDR* pNMHDR, LRESDLT* pResult) ; 
afxjmsg void OnDeleteMediaO ; 
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afxjtnsg void OnPlayMediaO ; 

afxjnsg void OnDblclk (NMHDR* pNMHDR, LRESULT* pResult) ; 
afxjnsg void OnClick (NMHDR* pNMHDR, LRESULT* pResult) ; 
afx_msg void OnColunmClick (NMHDR* pNMHDR, LRESULT* pResult) ; 
afxjnsg void OnRvnltemCallback (NMHDR* pNMHDR, LRESULT* pResult); 
afxjnsg void OnRvnSelectionChanged (NMHDR* pNMHDR, LRESULT* 
pResult) ; 

afxjnsg void OnNmRe turn (NMHDR* pNMHDR, LRESULT* pResult) ; 
afxjnsg void OnViewShowVGridO ; 

afxjnsg void OnUpdateViewShowVGrid(CCmdUI* pCmdUI) ; 
afxjnsg void OnViewShowHGridO ; 

afx_msg void OnUpdateViewShowHGrid(CCmdUI* pCmdUI) ; 
afxjnsg void OnViewShowHGridExO ; 

afxjnsg void OnUpdateViewShowHGridEx(CCmdUI* pCmdUI) ; 
afxjnsg void OnViewAlternateColors () ; 

afxjnsg void OnUpdateViewAlternateColors (CCmdUI* pCmdUI) ; 
//}}AFX_MSG 
DECLARE JVESSAGE_MAP ( ) 
private : 

xmlNodePtr currentFolderNode ; 

std; : vector <xmlNodePtr> current It emDat a ; 

int ra_iSelected; 

}; 

class SShowSort 

{ 

public: 

bool operator () (xmlNodePtrfc iteml, xrolNodePtrfc itetn2) ; 

}; 

class SEpisodeSort 

{ 

public : 

bool operator () (xmlNodePtrfc iteml, xmlNodePtrfc item2) ; 

}; 

class SDescriptionSort 

•{ 

public: 

bool operator () (xmlNodePtrfc iteml, xmlNodePtr& item2) ; 

}; ' 

class SReceivedSort 

{ 

public : 

bool operator () (xmlNodePtr& iteml, xmlNodePtrfc item2) ; 

}; 

• class SPublishedSort 
{ 

public : 

bool operator () (xmlNodePtr& iteml, xmlNodePtrfc item2); 

}; 

class SDaysToPurgeSort 

{ 

public : 

bool operator () (xmlNodePtrfc iteml, xmlNodePtrt item2) ; 

}; 

iiiiiiiiiiiiiiiiiiiiiniiiiiiiiiiiiiiiiiiiiiiimiiiumiiiuiiiitiuu 
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///// 

/ / { { AFX_INSERT_LOCATION } } 

// Microsoft Visual C++ will insert additional declarations immediately 
before the previous line. 

#endif // ! defined (AFX_DISPLAYVIEW_H_A7AFBE0C_5E5C_4EC4_88C5_ 
853C27172BF5 INCLUDEDj 
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// DownloadThread.cpp : implementation file 
// 

#include "stdafx.h" 

#include "player. h" 

#include "playerDoc.h" 

#include "globals.h" 

#include "DownloadThread.h" 

#include "ServerConnection.h" 

#ifdef _DEBUG 

#def ine new DEBUG_NEW 

#undef THIS_FILE 

static cliar THIS_FILE[] = FILE ; 

#endif 

inn i ii ii iiiiiiiiiiiiiiiiiiiiiiin n i m i minimum 7/ mini mini 
inn 

U CDownloadThread 

IMPLEMENT_DYNCREATE (CDownloadThread, CWinThread) 

CDovmloadThread : : CDownloadThread ( ) 
{ 

m_j?Doc = NULL; 
m_stopThread = false; 
m_jpMainHWnd = NULL; 
mJPCConn = NULL; 
// m_bAutoDelete = FALSE; 

} 

CDownloadThread : : -CDownloadThread (. ) 

{ 
} 

BOOL CDownloadThread: :Init Instance () 

^ // TODO: perform and per-thread initialization here 

return TRUE; 

} " 

int CDownloadThread: :ExitInstance() 

if (m_PCConn) 

delete m_PCConn; 
m_PCConn - NULL; 

return CWinThread: : Exit Instance () ; 

} 

BEGINJMESSAGEjyiAP (CDownloadThread, CWinThread) 
/ / { {AFX MSG MAP (CDownloadThread) 

H NOTE - the ClassWizard will add and remove mapping macros 

here. 

//}}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

unnininininnnnnniniiiiiiiinininiiiiniiiiiiiiiiiiiiiiiii 
inn u ^ 

II CDownloadThread message handlers 
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int CDownloadThread : : Run ( ) 

^ // Check the local document for validity. 

// Exit Thread if error, 
if (m_jpDoc == NULL) { 

TRACEO ("DownloadThread Error: PlayerDoc is NULL."); 
: : Pos tMessage (tn_pMainHWnd , WM_USERJDONE_DOWNLOAD , NULL , 
DT_NULLPLAYERDOC ) ; 

return Exitlnstance 0 ; 

} 

// Check the HWnd object. Exit Thread if error. 
• if (m_pMainHWnd == NULL) { 

TRACEO ( "DownloadThread Error: MainHWnd is NULL."); 

:: Pos tMessage (mj>MainHWnd, WM_USER_DONEJDOWNLOAD, NULL, 

DTJ3ULLHWND) ; 

return Exitlnstance () ; 

} 

// Establish a server connection. 

typedef vector<string>: : iterator VT; 

m_PCConn = new CServerConnection (mjpMainHWnd) ; 

// Get the Ip Address and Port of the server, 
string ipAddress » m_pDoc->GetServerIP() ; 
int portNuraber = mjpDoc->GetServerPortNum() ,- 
// Make a connection to the server. 
mJ?CConn- >connectPC ( ipAddress , portNuinber ) ; 

// Get the username, password and playerid. 
string username = m_j?Doc->GetUsername () ; 
string password » m_pDoc->GetPassword() ; 
string playerid = tnj>Doc->GetPlayerID() ; 
// Login into the server. 

m_PCConn-> login (username, password, playerid) ; 
// Start the icon animation. 

: :PostMessage(m_j>MainHWnd, WM_ USER_NOTIFYICON — ANIMATION^ START , 
(LPARAM) 0, (WPARAM)O); 

vector<string> v_eid; 
vector<string> v_sdesc; 
vector<string> v_edesc; 
vector<string> v_filename; 
vector<string> v_contenturls ; 
vector<string> v_contentmhtmls ; 

// Receive the Subscriptions from the server, 
m PCConn->recvSubs (&v_eid, &v_sdesc, &v_edesc, 
~ &v_f ilename, &v_contenturls , 

&v_contentmhtmls) ; 

/*************************** NOTE *******************************/ 

/* This is extrememly strange, if the doc was just create 

*/ 

/* IE the program is running for the first time, you need the 
* / 

/* first node, if its been run before you need the second. 
*/ 

/* The strange part is that the Folders view doesn't. have this 
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*/* problem. I think it might be that when AddNode is called, 

/* it doens't set next. When its read from a file, it does. 

™-iw«dePtr node = m pDoc->GetPolders () ->children->children; 
SEX tl ££> nod? - mj>Doc.>GetFolder S ()->children.>next-> 



children; 

xmlNodePtr inboxNode = NULL; 
bool done = falser- 
string strLabel; 
xmlNodePtr folder = node; 

SicEl(«ThreadFolder set to: %s\n% node->name) ; 

// Check for a valid inbox. 
// Exit thread if none exists. 
inboxNode = mj?Doc->GetInboxNodePtr () ; 

(LPARAM) ( ^^°Uage(m_ J3M ainHWnd, WM_XJSBR_DONE_DOWNLOAD , NULL, 

m INBOXERROR) ; 

return Exitlnstance () ; 

} 

time_t occurance; 
string curDateTime ; 
occurance « time (NULL) ; 
struct tm *today; 
char tmpbuf[128]; 
long int fsize; 



todav = local time(ficoccurance) ; 

strf?ime(?mpbuf, 128, «%a %m/%d/%y %Z.W %P", today ); 
curDateTime = tmpbuf; 

VI sdesclter = vjsdesc -begin 0 ; 

VI eidlter = v_eid. begin () ; 

VI edesclter = v_edesc begin () ; 

VI curllter - v_cont entur Is. begin () ; 

VI cmhtmllter = v_contentrahtmls .begin 0 ; 

// Each iteration receives a file. 

// Stop the loop if m_stopThread is true. 

for (VI i = v^filenameTbeginO; ( ( !m_stopThread) && d !- 

v filename.endO)); i++) { . n . 

string url = m_pDoc->GetDataDir () ; . 

string mhtmljpath = url; 

url = url +"\\ n + (*i>; % n _ n , < 

if( ( (string) *cmhtmllter) .length ( > 0 ) I 

mhtmljpath * mhtmljath + «\\« + (*cmhtmllter) ; 

llse mhtml^path = "none"; 

// Get Num Bytes About to Come Down. 

i£(!n «^^2fSS-' ( ""2" U file si- 

of next file to download."); . 

:: PostMessage (m_pMaxnHWnd, 
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NULL, DT_NETWORKERROR) ; 

return Exitlnstance ( ) ; 

} 

// Verify its ok to take in that many bytes. 

if ( !m_j?Doc->HaveAvailDiskSpace ( (unsigned int64) f size) ) { 

TRACE ( "DownloadThread Error: Disk Space Too Low."); 
: :PostMessage (m_pMainHWnd, 
WM_USER_NOTIFYICON_ANIMATION_END , (LP ARAM) 0 , (WPARAM) 0 ) ; 

:: PostMessage (mjpMainHWnd, WM_USER__DONE_DOWNLOAD , 
NULL, DT_DISKSPACEERROR) ; 

return Exitlnstance () ; 

} 

// Get the media file. 

if (m_PCConn->recvFile (url, f size) ) { 

// Download the METML if available. 

if ( ( (string) *cmhtmllter) . length ( ) > 0) { 

// Get Num Bytes About to Come Down. 

if ( !m_PCConn->getNuraBytesOfNextFile (&f size) ) { 

TRACE ( "DownloadThread Error: couldn't get 
file size of next file to download."); 

: :PostMessage (m_pMainHWnd, 
WM_US ER_N0T I F YI CON_ANIMATI ON__END , ( LPARAM) 0 , (WPARAM) 0 ) ; 

: :PostMessage (mjpMainHWnd, 
WM_USER_D0NE_DOWNLOAD , NULL, DTJNETWORKERROR) ; 

return Exitlnstance () ; 

} 

// Make sure the user has enough disk space for 

the file. 

// Exit thread and give an error message to the 

user if 

// the disk space is too low 

if ( !m_pDoc->HaveAvailDiskSpace ( (unsigned 

int64) f size) ) { 

MessageBox(m_pMainHWnd, "Disk space is low. 
The Synchronizer has been halted. It will not continue until disk space 
is freed. " , "Alert ! " , MB_OK | MB_ICONEXCLAMATION) ; 

TRACE ( "DownloadThread Error: couldn't get 
file size of next file to download. "); 

: : PostMessage (mjpMainHWnd, 
WM_USER_NOTIFYICON_ANIMATION_END , (LPARAM) 0 , (WPARAM) 0 ) ; 

:: PostMessage (mjpMainHWnd, 
WMJJSER_DONE_DOWNLOAD # NULL, DTJDISKSPACEERROR) ; 

return Exitlnstance (); 

} 

// Get the mhtml file. 

m PCConn->recvFile(mhtmlj?ath,fsize) ; 

} 

// Add the xml node for the recently downloaded file, 
if ( i m_stopThread) { 

mj>Doc->AddMediaToXML (inboxNode, url, 

*sdesclter, *eidlter, 

*edesclter, 

curDateTime , " - " , 

*curllter, 

rahtmljpath) ; 

mjoDoc - >Wri teXMLFoldersDoc ( ) ; 
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: :PostMessage(m_pMainHWnd, 
WM USER UPDATEALLVIEWS, (LPARAM)O, (WPARAM) 0) ; 
" " } 
} 

sdesclter++; eidlter++; edesclter++; curllter++; 
cmhtmllter++; 
} 

// Upload the Stats file unless m_stopThread is true. 
• if ( ( ! m_stopThread) && (m_PCConn- >ulStats (m_j>Doc- > 
GetStatsFileLocation ( ) ) ) ) { 

/* clear the file. */ 
FILE *sfd; 

sfd = fopen(mjpDoc->GetStatsFileLocation() .c_str () , "wb+"); 
f close (sfd) ; 

// MFC stats. clear stats 
(mj>Doc->GetStats () ) - >clearStats ( ) ; 

} 

: :PostMessage(m^MainHWnd, WM_US ERJSTOT I FY I CON_ANIMAT I ON_END , 
(LPARAM) 0, (WPARAM) 0) ; 

if (m stopThread) { 

' ~ : rPostMessagetmjpMainHWnd, WM_USER__DONE_DOWNL0AD , NULL, 

DTJDOWNLOADABORTED) ; 

return BxitlnstanceO ; 

} 

: rPostMessageCmjMainHWnd, WM_USERJDONE JX)WNLOAD , NULL, 
DT_DOWNLOADSUCCESSFUL) ; 

return Exitlnstance 0 ; 

} 

// Purpose: Set the Player Document and m_j>MainWnd 
II to the passed in variables . 

// Returns: DT_NOERROR if params are valid. 

// DT_PDOCNULL if pDoc is invalid. , 

//' DT_HWNDNULL if cWnd is invalid. 

// DT_PDOCNULL + DT_HWNDNULL if both pDoc and cWnd are 

int^ownloadThread: : SetParameters (HWND >Wnd, CPlayerDoc *pDoc) 

// Set vars. 
m_j?Doc = pEoc ; 
m_pMainHWnd a hWnd; 

// Initialize error variable. 

// Return false if parameters are invalid. 

int error = DT_N0ERROR ; 

if (lm_pDoc) error +« DT_PDOCNULL; 

if ( lm_pMaiiiHWnd) error += DT_HWNDNULL; 

// Parameters were valid so return true, 
return error; 

} 

// Purpose: Set m_stopThread to stop the thread, 
void CDownloadThread: :KillThread() { 
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m_s topThread = true; 
m PCConn->stop() ,- 

} 
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#i f ! defined(AFX_DO^O M THREA D _H_ 6 CCB86C8_42A2_4 9 4F.B096_2783 6 7C04M)0 
_INCLUDED_ 



#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

// DownloadThread.h : header file 

// 



// SetParameters Error Codes. 
#def ine DT_NOERROR ~ 
#def ine DT_PDOCNULL 
#def ine DT_HWNDNUIiL 



#def ine DTJPDOCNULL 
#def ine DTJHWNDNULL 
#def ine DT_PDOC_AND_HI^_NULL 3 



// Thread Return Codes. 

#def ine DTJDOWNLOADSUCCESSFDL 1 

#def ine DTJDOWNLOADABORTED 0 

#def ine DTJTOIJjPIiAYERDOC * _1 

#define DT__NULLHWND " 

#def ine DTJCNBOXERROR 

#def ine DT_DISKSPACEERROR 

#def ine DT_NETWORKERROR " 5 

/ ,nn,,,,/nnni/nni/niiff///n/n/n/fffHn//////ni//nniu!n/ 

II CDownloadThread thread 
class CPlayerDoc; 

class CDownloadThread : public CWinThread 

* DECLARE JDYNCREATE (CDownloadThread) . 

protected : 

CDownloadThread ( ) ; 

// Attributes 

PUbUC int SetParameters (HWND hWnd, CPlayerDoc* pDoc) ; 
void KillThreadO ; 

// operations 
public: 

// Overrides^^^ vi j function overrides 

// { {AFX_VIRTUAL (CDownloadThread) 
public; 

virtual BOOL InitlnstanceO ; 
virtual int ExitlnstanceO ; 
virtual int Run(); 
//}}AFX_VIRTUAL 

// implementation 

pr ° teC virtual -CDownloadThread () ; 

// Generated message map functions 
// { { AFXjyiSG (CDownloadThread) 
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// NOTE - the ClassWizard will add and remove member 
functions here. 

//}}AFX_MSG 

DECLARE JYES S AGE_MAP ( ) 

private : 

CServerConnection* m_PCConn; 
HWND m_j)MainHWnd; 
CPlayerDoc *m_j?Doc; 
bool m_stopThread; 

}; 

//////////////////////////////////////////////////////////////////////// 
///// 

// { { AFX_INSERT__IiOCATT ON } } 

// Microsoft Visual C++ will insert additional declarations immediately 
before the previous line. 

#endif // !def ined (AFX_DOVmLOADTHREAD_H_6CCB86C8_42A2_494F_B096_ 
2783 67C04AD0 INCLUDED^) 
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// ErrorDlg.cpp : implementation file 
// 

#include "stdafx.h" 
#include "player. h" 
#include "ErrorDlg.h" 

ftifdef _DEBUG 

#def ine new DEBUG_NEW 

ftundef THIS_FILE 

static char THIS_FILE [] = FILE — ; 

#endif 

,//H///iu//nii//!/uui/u///////fi/iu/n//nn///if/tf//mu/i/i// 
um 

II CErrorDlg dialog 

CErrorDlg:: CErrorDlg (Otod* pParent /*=HULL*/) 
: OTialog (CErrorDlg : :IDD, pParent) 

^ / / { { AFX_DATA_JENIT (CErrorDlg) 

mjnsg = JT ( " " ) ; 

/ / } } AFXJDATAJENIT 

} 

void CErrorDlg: :DoDataExchange (CDataExchange* pDX) 

^ CDialog : : DoDataExchange (pDX) ; 

/ / { {AFX DATAJOAP (CErrorDlg) 
DDX_Control (pDX, IDCJ3DIT1, tnmsgCtrl) ; 
DDX Text(pDX, IDC_EDIT1, m_msg) ; 
// }JAFXJ3ATA_MAP 

} 

BEGINjyiESSAGE_MAP( CErrorDlg/ CDialog) 

//}}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

////////////////////////////////// ////////////////////////////7///////// 

urn Jn 

// CErrorDlg message handlers 
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#if Idef ined (AFX_ERRORDLG_H_B30202B9_B782_48D6_AECA_D860727B6664 

INCLUDED ) 
#define AFX_ERRORDLG_H_B30202B9^ 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 
// ErrorDlg.h : header file 
// 

1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 II 1 1 H 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 
//./// 

II CErrorDlg dialog 

class CErrorDlg : public CDialog 

// Construction 
public : 

CErrorDlg (CWnd* pParent = NULL); // standard constructor 

// Dialog Data 

// { {AFX_DATA (CErrorDlg) 

enum { IDD = IDD_ERROR_DLG }; 

CEdit mjmsgCtrl; 

CString m_msg; 

/ / } } AFX_DATA 



// Overrides % , 

II ClassWizard generated virtual function overrides 
// { {AFX_VIRTUAL (CErrorDlg) 

protected: fc . . 

virtual void DoDataExchange (CDataExchange* pDX) ; / / . DDX/DDV 

support 

//}}AFX_VIRTUAL 

// Implementation 
protected: 

// Generated message map functions 
//{{AFX MSG (CErrorDlg) 

fj NOTE: the ClassWizard will add member functions here 

//}}AFX MSG 
DECLAREJtfESSAGE_MAP ( ) 

}; 

//{{AFX INSERT LOCATION}} . 
// Microsoft visual C++ will insert additional declarations immediately 

before the previous line. 

#endif // I defined (AFX_ERRORDLG_H_B3 0202B9_B782_48D6_AECA_D860727B6664 
INCLUDED ) 



104 



WO 03/010634 



PCT/US02/23713 



llllllllllllllllllllllllllllllllllllllllllllllll 11111111111 " 1 """"" 



File: 
Version: 

Author : 
E-mail : 



//// 
ii 
ii 
ii 
ii 
ii 
if 
ii 
ii 
ii 
ii 
ii 
ii 
ii 
ii 
ii 

well. 

// • 

// This 
warranty. 
II 

that 
II 



CFlatHeaderCtrl . cpp 
1.0.6 

Maarten Hoeben 
hoeben@nwn . com 



II 
II 
II 
II 
II 
II 
II 

a static 
II 



Implementation of the CFlatHeaderCtrl and associated classes. 

This code may be used in compiled form in any way y™J£*}*?' ^ s 
file may be redistributed unmodified by any means PROVIDING it is 
not sold for profit without the authors written consent, and 
providing that this notice and the authors name and all copyright 
notices remains intact. 

An email letting me know how you are using it would be nice as 

file is provided "as is" with no expressed or implied 
?he author accepts no liability for any damage/loss of business 
this product may cause. 



Version history 



1.0 
1.0 



.0 

.1 



// 1.0.2 - 
II 
II 
II 
II 
II 

image dimensions) 

II 

II 

limitation 

II 

II 

II 

drag&drop 

// 

II 

II 

items 
// 



Fixed FHDragWnd destroy warning (thanks Phxlippe Terrier) 

- Fixed double sent HDNJETEMCLICK 

- Added a property that adjusts for ListCtrls that use 

border for flat look. 
Fixed another destroy warning t 

- Fixed Insertltem array exception handling 

- Fixed incorrect header width painting 

- Changed Drawltem argument passing 

- Changed HDITEMEX struct item names 
Added handler for HDM_SETIMAGELIST 



(precalculate 



Changed Drawlmage to clip images 

Changed Insertltem ASSERT check to position 

Added new-style "HotDivider" arrows 
Fixed some GDI objects 

Added 'don't drop cursor 1 support to indicate 

outside control ' 

Added drag&drop target window support 

Changed CFHDragWnd to support externally created- 



// 
// 
// 
// 
// 
// 
// 
// 
// 



- Removed topmost-style from CFHDropWnd 

- Fixed OnSetHotDivider order bug 

- Added extended styles 

- Added item width estimation function 
1.0.3* - Added WMJ2ANCELMODE handler 

1.0.4 - Changed copyright message 

- Added tooltip style 
1.0.5 - Added persistent style 

- Added definitions for drop result 

- Added height manipulation functions 
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// 
// 
// 



1.0.6 - Fixed bitmap drawing resource leak 
- Added proper font handling. 



iiiiiiiiuiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiuiiiniiiiiiiiiiiiiiiiiiiiii 
mi 



II FlatHeaderCtrl.cpp : implementation file 



#include "stdafx.h" 
#include "FlatHeaderCtrl . h M 

#include <afxpriv.h> 

#include "MemDC.h" 

#if def _DEBUG 

#def ine new DEBUG_NEW 

#undef THIS_FILE 

static char THIS_FILE[] = FILE ; 

#endif 



/ /III 11/11 l/l/lll/ll If /III fill II III I //////////// //III/ f/llllllt/l II 11/11 

inn 

1/ CFHDragWnd 



CFHDragWnd : : CFHDragWnd ( ) 

// Register the window class if it has not already been 
registered. 

WNDCLASS wndclass; 

HINSTANCE hlnst = AfxGetlnstanceHandle () ; 

if ( ! ( : :GetClassInf o (hlnst, FHDRAGWND_CLASSNAME , fcwndclass) ) ) 



// otherwise we need to register a new class 
wndclass. style = CS_SAVEBITS ; 
wndclass . IpfnWndProc = : :DefWindowProc; 
wndclass.cbClsExtra = wndclass . cbWndExtra = 0; 
wndclass. hlnstance = hlnst; 
wndclass. hi con = NULL; 

wndclass. hCursor « LoadCursor( hlnst, IDC_ARROW) ; 
wndclass. hbrBackground = (HBRUSH) (COLOR_3DFACE + 1) ; 
wndclass. IpszMenuName = NULL; 

wndclass -IpszClassName = FHDRAGWND_CLASSNAME ; 
if ( ! AfxRegisterClass (fcwndclass) ) 
AfxThrowResourceException ( ) ; 



// 



{ 




} 

CFHDragWnd : : -CFHDragWnd ( ) 



BEGIN MESSAGE MAP (CFHDragWnd, CWnd) 
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/ / { {AFX_MSGJVIAP (CFHDragWnd) 
ON__WM_PAINT() 
ONJMJSRASEBKGND ( ) 
//}}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

// //////////////////////////////////////// ////////////////////////////// 

//^CFHDragWnd message handlers 

BOOL CFHDragWnd: :Create(CRect rect, CFlatHeaderCtrl* pFlatHeaderCtrl , 
INT iltem, LPHDITEM lphdiltem) 

! jss^sassssssiiof > > - 

mj>FlatHeaderCtrl « pFlatHeaderCtrl; 
m_iltem = litem; 
mJLphdiltem = lphdiltem; 

nOTT > dwStvle = WS POPUP I WS DISABLED ; 
SwSS dwIStyle !V^_^™l WS - EX - T0PM0ST; 



return CreateExtdwExStyle, FHDRfcGWND OM™. "J*' f dwStyle, 
rect. left, rect. top, rect. Width () , rect.Hexght () , 



} 



NOLL, NULL, NULL ) ; 



void CFHDragWnd: :OnPaint () 

^ CPaintDC dc (this) ; 

if (m_pFlatHeaderCtrl - >m_bDoubleBuf f er) 

' l CMemDC MemDC(fcdc) ; 
OnDraw(ScMemDC) ; 

} 

else 

OnDraw(fcdc) ; 

} 

BOOL CFHDragWnd: :OnEraseBkgnd(CDC* pDC) 

^ return TRUE; 
} 

void CFHDragWnd: :OnDraw( CDC* pDC) 

^ CRect rect; 

GetClientRect (rect) ; 



m _pFlatHeaderCtrl->ro_cr3DShadow) ; 

P DC->SetBkColor ( m _pFlatHeaderCtrl->m_cr3DFace) ; 
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pDC->SetTextColor (m_pFlatHeaderCtrl->m_crText) ; 

rect.DeflateRect (mjpFlatHeaderCtrl->m_iSpacing, 0) ; 
m j>FlatHeaderCtrl - >DrawItem ( 

pDC, 

rect, 

m_lphdiltem, 

mj>FlatHeaderCtrl->m_iSortColumn == m_iltem, 
m_pFlatHeaderCtrl - >m_bSortAscending 

); 

pDC->SelectObject (pFont) ; 
pDC->SelectObject (pPen) ; 



void CFHDragWnd : : PostNcDestroy ( ) 

CWnd : : PostNcDestroy ( ) ; 
delete this; 



//////////////////////////////////////////////////////// //////////////// 
///// 

// CFHDropWnd 

CFHDropWnd : : CFHDropWnd (COLORREF cr Color) 

1 m_brush . CreateSolidBrush (crColor) ; 

// Register the window class if it has not already been 
registered, 

WNDCLASS wndclass; 

HINSTANCE hlnst = AfxGetlnstanceHandle () ; 

if ( ! ( : :GetClassInf o (hlnst, FHDROPWND^_CLASSNAME , &wndclass) ) ) 

^ // otherwise we need to register a new class 
wndclass . style = CS_SAVEBITS ; 
wndclass. lpfnWndProc - : :DefWindowProc; 
wndclass. cbClsExtra = wndclass. cbWndExtra = 0; 
wndclass. hlnstance = hlnst; 
wndclass. hl.con = NULL; 

wndclass. hCursor = LoadCursor( hlnst, IDC.ARR0W ); 
wndclass. hbrBackground = ( HBRUSH ) mjbrush ; 
wndclass. IpszMenuName = NULL; 

wndclass. IpszClassName = FHDROPWND_CLASSNAME ; 
if ( » AfxRegisterClass (&wndclass) ) 
Af xThrowResourceException ( ) ; 



CFHDropWnd: : -CFHDropWnd ( ) 



BEGIN_ME SSAGE_MAP (CFHDropWnd, CWnd) 
/ / { {AFX_MSG_MAP (CFHDropWnd) 
ON_WM_ERASEBKGND ( ) 
//}}AFX_MSG_MAP 

END MESSAGE MAP() 
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iiiiiiiiiiiiiiiiiiiiiiii i an iniiiiiiin ii ii in i iin iiiiiiiiiiiun an 

11111 u „ 

II CFHDropWnd message handlers 

BOOL CFHDropWnd: : Create (INT iHeight) 

^ m_iHeight = iHeight + 20; 

DWORD dwStyle = WS_POPUP | WS_ DISABLED ; 
DWORD dwExStyle = WS_EXJTOOLWINDOW ; 

BOOL bResult = CreateEx(dwExStyle, FHDROPWND_CLAS SNAME , NULL, 
dwStyle, 

0, 0, 12, m_iHeight, 
NULL, NULL, NULL } ; 

CRgn rgnl, rgn2; 
POINT ptArrow[7] ; 

ptArrow[0].x = 8; ptArrow[0] .y = 0; 
ptArrow[l] .x = 8; ptArrow[l] .y = 4; 
ptArrow[2] .x = 11; ptArrow[2] .y = 4; 

ptArrow[3j.x = 6; ptArrow[3] -y = 9; 
ptArrow[4] .x = 1; ptArrow[4] .y = 4; 
ptArrow[5].x = .4; ptArrow[5] .y » 4; 
ptArrow[6] .x = 4; ptArrow[6] .y = 0; 
rgnl.CreatePolygonRgn(ptArrow, 7,- ALTERNATE); 

ptArrow[0] .x = 4; ptArrow[0] .y = m_iHeight; 
ptArrow[l] .x = 4; ptArrow[l] .y = m_iHeight-4; 
ptArrow[2].x = 0; ptArrow[2] .y = m_iHeight-4 ; 
ptArrow[3] .x = 6; ptArrow[3] .y = mJ.Height-10; 
ptArrow[4] -x = 12; ptArrow[4l .y = m _iHeight-4; 

ptArrow[5].x = 8; ptArrow[5] .y = tnjLHeight-4 ; 
ptArrow[6]*.x = 8; ptArrow[6] -y = m_iHeight; 
rgn2.CreatePolygonRgn(ptArrow, 7, ALTERNATE); 

m rgn.CreateRectRgn(0, 0, 12, iHeight); 
irTrgn . CorabineRgn ( fcrgnl , . &rgn2 , RGNJDR) ; 
SetWindowRgn(m_rgn, FALSE); 

rgnl .DeleteOb ject ( ) ; 
rgn2 .DeleteOb ject 0 ; 

return bResult ; 

} 

void CFHDropWnd : : PostNcDestroy ( ) 

^ mjrgn . DeleteOb j ect ( ) ; 

CWnd: : PostNcDestroy 0 ; 
delete this; 

} 

BOOL CFHDropWnd: :OnEraseBkgnd( CDC* pDC) 
{ 
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pDC->FillRect (CRect (0, 0, 12, m_iHeight) , &m_brush) ; 
return TRUE; 

} 

void CFHDropWnd: :SetWindowPos (INT x, INT y) 
{ 

CWnd: : SetWindowPos { 
fcwndTop, 

x-6, y- (m_iHeight/2) , 

0, 0 7 SWP_NOSIZE|SWP_SHOWWINr)OW|SWP_NOACTIVATE 

) ; 

} 

//////////////////////////////////////////////////////////////////////// 
///// 

// CFlatHeaderCtrl 

IMPLEMENTED YNCREATE ( CFlatHeaderCtrl , CHeaderCt rl ) 

CFlatHeaderCtrl : : CFlatHeaderCtrl () 
{ 

m_bDoub 1 eBuf f e r = TRUE; 
m_i Spacing = 6; 
m_sizeArrow.cx = 8; 
ra_sizeArrow.cy =8; 
m_sizelmage . cx =0; 
m_sizelmage.cy = 0; 
m_bStaticBorder = FALSE; 
m_nDontDropCursor = 0; 
m_hDropTarget = NULL; 
m_rcDropTarget.SetRectEmpty() ; 
m_iDropResult = FHDR_ONHEADER; 

ra_iHot Index = -1; 
Ttt_bHotIteinResizable = FALSE; 

m_bResizing = FALSE; 

m_iHotDivider = -1; 
m_crHotDivider = 0x000 00 OFF; 
m_pDropWnd = NULL; 

m_bDragging = FALSE; 
m_pDragWnd = NULL; 

m_nClickFlags = 0; 

m_bSortAscending = FALSE; 
m_i Sort Column = -1; 
m_arrayHdrItemEx.SetSize (0, 8) ; 

m_iHeight= -1; 

m_cr3DHighLight = : : GetSys Color (COLOR_3DHIGHLIGHT) ; 
m_cr3DShadow = : :GetSysColor (COLOR_3DSHADOW) ; 
m_cr3DFace = ; : GetSys Color (COLOR_ 3DFA CE) ; 
m_crText = : :GetSysColor (COLOR_BTNTEXT) ; 

m_font.CreateStockObject ( DEFAULT J3OT_FONT ); 
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CFlatHeaderCtrl : : -CFlatHeaderCtrl ( ) 

^ if (m_f ont - m_liOb j ect ) 

m_f ont • DeleteOb j ect ( ) ; . 

if (mjpDropWnd != NULL) 

m_pDropWnd- >DestroyWindow ( ) ; 
mjpDropWnd = NULL; 

if (mjpDragWnd != NULL) 

^ m_jpDragWnd- >DestroyWindow ( ) ; 

mjpDragWnd = NULL; 



BEGIN_MESSAGE _MAP ( CFlatHeaderCtrl , CHeaderCtr 1 ) 

/ / { { AFX_MSG_MAP (CFlatHeaderCtrl) 

ONJ4ESSAGE (HDM_INSERTITEMA, Onlnsertltem) 

ON_MESS AGE (HDM_INSERTITEMW , Onlnsertltem) 

ON_MESSAGE(HDM_DELETEITEM, OnDeleteltem) 

ON_MESSAGE (HDM_SETIMAGELIST, OnSetlmageList) 

ONJ4ESSAGE (HDM__SETHOTDIVIDER , OnSetHotDivider) 

ON_ MESSAGE (HDM_LAYOUT , OnLayout) 

ON_NOTIFY_EX (TTN_NEEDTEXTA, 0, OnToolTipNotify) 

ON_NOTIFY_EX (TTN_NEEDTEXTW , 0, OnToolTipNotify) 

ONJflM_NCHITTEST () 

ONJKM_SETCURSOR ( ) 

ONJtfM_LBUTTONDOWN ( ) 

ON_WM_LBUTTONDBLCLK ( ) 

ON_WM_PAINT() 

ONJM_SYSCOLORCHANGE ( ) 

ON__WM_ERASEBKGND ( ) 

ON_WM_LBUTTONUP ( ) 

ON_WM _MOUSEMOVE ( ) 

ON_WM_CANCELMODE ( ) 

//}}AFX_MSG_MAP 
ONjyiESSAGE (WM_SETFONT, OnSetFont) 
ONJMESSAGE ( WM_GETFONT , OnGetFont ) 
END_MESSAGE_MAP ( ) 

//////////////////////////////////////////////////// ///////////////7//// 
///// 

// CFlatHeaderCtrl attributes 

BOOL CFlatHeaderCtrl: :ModifyProperty (WPARAM wParam, LPARAM lParam) 

switch (wParam) 
{ 

case FH_PROPERTY — SPACING : 

m_iSpacing = (INT)lParam; 
break; 

case FH_PROPERTY_ARROW: 

m_sizeArrow. cx = LOWORD(lParam) ; 
m_sizeArrow.cy = HIWORD(lParam) ; 
break; 

case FH PROPERTY^ STATICBORDER : 
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m_bStaticBorder « (BOOL) 1 Par am; 
break; 

case FH_PROPERTY_DONTDROPCURSOR : 

m_nDontDropCursor = (UINT) lParam; 
break; 

case FH_PROPERTY__DROPTARGET : 

m_hDropTarget = (HWND) lParam; 
break; 

case FH_PROPERTYJEMABLETOOLTIPS : 

EnableToolTips ( (BOOL) lParam) ; 
break; 

default : 

return FALSE ; 

} 

Invalidate ( ) ; 
return TRUE; 

} 

BOOL CFlatHeaderCtrl: :GetItemEx(INT iPos, HDITEMEX* phditemex) const 

^ if (iPos>=ra_arrayHdrItemEx.GetSize () ) 
return FALSE; 

phditemex- >nStyle = m_arrayHdrItemEx[iPos] .nStyle; 
phditemex- >iMinWidth = m_arrayHdrItemEx[iPos] -iMinWidth; 
phditemex- >iMaxWidth = m_arrayHdrItemEx[iPos] .iMaxWidth; 
phditemex- >strToolTip = m_arrayHdrItemEx [iPos] .strToolTip; 
return TRUE; 

} 

BOOL CFlatHeaderCtrl: : Set ItemEx( INT iPos, HDITEMEX* phditemex) 

^ if (iPos>=m_arrayHdrItemEx.GetSize () ) 
return FALSE; 

BOOL bUpdate o FALSE; 

HDITEM hditem; 
hdi tern, mask = HDI_WIDTH; 
if ( ! Get I tern (iPos , fihditem) ) 
return FALSE; 

HDITEMEX hditemex = *phditemex; 

if (hditemex. nStyle&HDF_EX_AUTOWIDTH) 

^ TCHAR szText [FLATHEADER_TEXT_MAX] ; 

HDITEM hdi; 
hdi. mask = 

HDIJtflDTH | HDI_FORMAT j HDI JTEXT | HDI_IMAGE | HDI_BITMAP; 
hdi.pszText = szText; 
hdi . cchTextMax = sizeof (szText) ; 
VERIFY ( Get Item ( iPos , &hdi ) ) ; 

hditem. cxy = GetItemWidth(&hdi, 
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hditemex.nStyle&HDF_EX_lNCLUDESORT ? TRUE: FALSE) ; 
bUpdate = TRUE; 

} 

if ( ( ! (hditemex.nStyle & HDF_EX_FI X EDWIDTH) ) (hditemex. iMinWidth 
<=hditemex. iMaxWidth) ) 

* if (hditem.cxy < hditemex . iMinWidth) 

^ hditem.cxy = hditemex. iMinWidth; 
bUpdate = TRUE; 

} 

if (hditem.cxy > hditemex . iMaxWidth) 

* hditem.cxy = hditemex. iMaxWidth; 
bUpdate = TRUE; 

} 

} 

if (bUpdate) 

SetItem(iPos, &hditem) ; 

m_ar rayHdr 1 1 emEx . SetAt ( iPos , hditemex) ; 
return TRUE; 

XNT CFlatHeaderCtrl^GetltemWidthtLPHDITEM Ipndi, BOOL blncludeSort) 

^ INT iWidth - 0; 

CBitmap* pBitmap = NULL; 

BITMAP biBitmap; 

if (lphdi->fmt£EDF_BlTiyiAP) 

^ ASSERT (lphdi->mask&HDI_BITMAP) ; 

ASSERT (lphdi->hbm) ; 

pBitmap = CBitmap: :FrotnHandle(lphdi->hbm); 

if (PBitmap (pB . tmap . >Getobject (size cf (BITMAP) , BiBitmap) ) ; 

} 

Sh J- blncludeSort ^m.sizeArrow.cx+m^SpacxngtO; 

if (lphdi->ma S k&HDI_TEXT && lphdi - > f mt SHDF_STRING ) 

^ CClientDC dc(this); . 

CFont* pFont = dc . SelectOb j ect (GetFont ( ) ) ; 

iWidth +- dc.GetTextExtent(lphdi->ps Z Text) .cx + m.iSpacing; 
dc . SelectOb j ect (pFont) ; 

} 

return iwidth; 



113 



WO 03/010634 



PCT/US02/23713 



void CFlatHeaderCtrl : :SetSortColumn (INT iPos, BOOL bSortAscending) 
^ ASSERT (iPos < GetltemCount ()) ; 

m_bSortAscending = bSortAscending; 
m_iSortColumn = iPos; 
Invalidate () ; 

} 

INT CFlatHeaderCtrl : : Get Sort Column (BOOL* pbSortAscending) 

^ if (pbSortAscending) 

♦pbSortAscending = m_bSortAscending; 

return injLSortColutnn; 

} 

INT CFlatHeaderCtrl : : GetDropResult ( ) 
{ 

return ra_iDropResult; 

} 

INT CFlatHeaderCtrl : : GetHeight ( ) 
{ 

if (m iHeight <= 0) 
{ " 

CRect rect; 
GetWindowRect (rect) ; 

return rect . Height ( ) ; 

} 

else 

return m_iHeight; 

} 

void CFlatHeaderCtrl: :SetHeight( INT iHeight) 
m_iHeight = iHeight ; 

} 

/////////////////////////////////////////////////////'"""""" ////// 

urn 

II CFlatHeaderCtrl implementation 

void CFlatHeaderCtrl: :DrawCtrl (CDC* pDC) 
{ 

CRect rectClxp; 

if (pDC->GetClipBox(&rectClip) == ERROR) 
return; 

CRect rectClient, recti tern; 
GetClientRect(&rectClient) ; 

pDC->FillSolidRect(rectClip, m_cr3DFace) ; 

INT iltems = GetltemCount 0 ; 
ASSERT (il terns >= 0) ; 

CPen penHighLight(PS_SOLID, 1, m_cr3DHighLight) ; 
CPen penShadow(PS_SOLID, 1, m_cr3DShadow) ; 
CPen* pPen = pDC->Get Current Pen () ; 
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CFont* pFont = pDC->SelectObject(GetFont () ) ; 

pDC->SetBkColor (m_cr3DFace) ; 
pDC ->SetText Color (ra_crText) ; 

INT iWidth = 0; 

for (INT i=0;i<iltems;i++) 

^ INT iltem = OrderToIndex(i) ; 

TCHAR szText [FLATHEADERJTEXT_MAX] ; 

HDITEM hditem; 
hditem. mask = 
HDI WIDTH | HDI_FORMAT | HDIJTEXT | HDIJCMAGE | HDIJ3ITMAP ; 
hditem. pszText = szText ; 
hditem. cchTextMax = sizeof (szText) ; 
VERIFY (Get Item (iltem, fchditem) ) ; 

VERIFY (GetltemRect (iltem, rectltem) ) ; 

if (rectltem. right >= rectclip . lef t || rectltem. left <= 
rect Clip, right) 

^ if (hditem. fmt&HDF_OWNERDRAW) 

^ DRAWITEMSTRUCT disltem; 

disItem.CtlType = ODT_BUTTON; 
disItem.CtllD = GetDlgCtrlID() ; 
disltem. itemID = iltem; 
disltem. it emAct ion = ODA_DRAWENTIRE; 
disltem. itemState = 0; 
disltem . hwndltem = . m_hWnd ; 
disItem.hDC = pDC->m_hDC; 
disltem.rcltem = rectltem; 
disltem. itemData = 0; 



} 

else 

{ 



Drawltem(&disltem) ; 



rect Item. Def lateRect (m_iSpacing, 0) ; 
Drawl tern (pDC, rectltem, &hditem, iltem == 



m iSortColumn, m bSortAscending) ; 
- - rectltem. Inf lateRect (m_iSpacxng, 0) ; 

if ( m__nC 1 i c kF 1 ag s &MK_LBtJTTON && m_iHot Index == 

iltem && m hdhtiHotltem. f lags&HHT_ONHEADER) 

_ P DC->InvertRect (rectltem) ; 

} 

if(i < iltems-l) 

pDC- >SelectOb j ect ( fcpenShadow) ; 

pDC- >MoveTo (rectltem . right - 1 , rectltem . top+2 ) ; 

pDC->LineTo (rectltem. right-1, rectltem. bottom- 

2); 

pDC- >SelectOb j ect ( &penHighLight ) ; 
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} 



pDC->MoveTo (rectltem. right, rectltem. top+2) ; 
pDC->LineTo (rectltem. right, rectltem. bottom-2) ; 

} 

iWidth += hditem.cxy; 

} 

if (iWidth > 0) 

rectClient .right = rectClient.lef t + iWidth; 
pDC->Draw3dRect (rectClient, m_cr3DHighLight, m_cr3DShadow) 

} 

pDC->SelectObject (pFont) ; 
pDC->SelectObject (pPen) ; 

penHighLight.DeleteObject () ; 
penShadow.DeleteObject 0 ; 



void CFlatHeaderCtrl : : Drawl t em (LPDRAWITEMSTRUCT) 

ASSERT (FALSE) ; // must override for self draw header controls 

} 

void CFlatHeaderCtrl :.:DrawItem (CDC* pDC, CRect rect f LPHDITEM lphdi, 
BOOL bSort, BOOL bSortAscending) 

ASSERT ( lphdi - >mask&HDI_FORMAT) ; 

INT iWidth = 0; 

CBitmap* pBitmap = NULL; 

BITMAP Bitmaplnfo; 

if ( lphdi - > f mt &HDF_BITMAP ) 

ASSERT ( lphdi - >mask&HDI_BITMAP ) ; 
ASSERT ( lphdi ->hbm) ; 

pBitmap = CBitmap: :FromHandle( lphdi ->hbm) ; 
if (pBitmap) 

VERIFY (pBitmap- >GetObject (sizeof (BITMAP) , 

&BitmapInfo) ) ; 

} 

switch ( lphdi->fmt&HDF_JUSTIFYMASK) 
{ 

case HDF_LEFT : 

rect.left += (iWidth = Drawlmage (pDC, rect, lphdi, FALSE) ) ? 
iWidth+m_iSpacing : 0; 

if (lphdi ->fmt&HDF_IMAGE && ! iWidth) 
break ; 

rect. right -= bSort ? m_iSpacing+m_sizeArrow.cx : 0; 
rect.left += (iWidth = DrawText (pDC, rect, lphdi)) ? 
iWidth+m_iSpacing : 0; 

if(bSort) 
{ 

rect -right += ra_i Spac ing+tn_s x z eArrow . cx ; 
rect.left +« DrawArrow(pDC, rect, bSortAscending, 

FALSE) +ra_iSpacing; 
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DrawBittnap(pDC, rect, lphdi, pBitmap, fiBitmapInfo, TROE) ; 
break; 

case HDF_CENTER: += = DrawImage (pDC , rect , lphdi/ FALSE) ) » 

iWidth+m iSpacing : 0; 

~ if (lphdi->frat&HDF_IMAGE && 1 1 Width) 

break; 

rect left += bSort ? mjLSpacing+mjsizeArrow.cx : 0; 
rect ".right — (iWidth=DrawBitmap(pDC, rect, lphdi, pBitmap, 
&BitmapInfo, TRUE) ) ? iWidth+m_iSpacing:0; 
if (bSort) 

^ rect. left -= m_iSpacing+m_sizeArrow.cx; 

rect. right DrawArrow(pDC, rect, bSortAscendmg, 
TRUE) +2*m_iSpacing; 

DrawText (pDC, rect, lphdi) ; 
break; 

case HDF RIGHT: 

ifTl (lphdi->fmt&HDFJBITMAP_ON_RIGHT) ) 

rect. left += (iWidth=DrawBitmap (pDC, rect, lphdi, 
pBitmap, fiBitmapIUfo, FALSE) ) ? iWidth + m_iSpacing = 0 ; 

rect. left +« {iwidth = DrawImage (pDC, rect, lphdi, FALSE) ) ? 

iWidth+m iSpacing : 0; 

if (lphdi- >fmt&HDF_IMAGE && IlWidth) 

break; 

rect. left +» bSort && ( lphdi - > fxnt &HDF_B I TMAP__ON_RIGHT ) ? 
m iSpacing+m sizeArrow.cx : 0; 
- If (lphdi->fmt&HDF BITMAP_ONRIGHT) 

rect. right -= (iWidth=DrawBitmap (pDC, rect, lphdi, 
pBitmap, &BitmapInfo, TRUE) ) ? iWidth+m_iSpaciiig:0; 
if (bSort) 

{ rect. left -= ( lphdi - > f mt &HDF_B ITMAP_0'N_RIGHT ) ? 

^iS P acing +ra „si 2 e^ow.g:0; ^ DrawArrow(pDC/ rect/ bSortAsce nding, . 
TRUE ) +2 *m_iSpacing ; 

DrawText(pDC, rect, lphdi); 
break; 

} 

} 

INT CFlatHeaderCtrl::DrawImage(CDC* pDC, CRect rect, LPHDITEM lphdi, 
BOOL bRight) 



{ 



CTmageList* plmageList = GetlmageList ( ) ; 
INT iWidth = 0; 



if (lphdi->mask&HDI_IMAGE && lphdi- >fmt£HDF_IMAGE) 

1 ASSERT (plmageList) ; . 

ASSERT (lphdi->ilmage>=0 && lphdi->Hmage<pImageList-> 

GetlmageCount ( ) ) ; 
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if (rect. Width ()>0) 
{ 

POINT point; 

point. y = rect . Center Point (). y - (m_sizelmage. cy»l) ; 
if (bRight) 

point. x = rect. right - m_sizelmage.cx; 

else 

point. x = rect. left; 
SIZE size; 

size.cx = rect . Width () <m_sizelmage.cx ? rect. Width 

{) :m_sizelmage.cx; 

size.cy = m_sizelmage.cy; 

pImageList->DrawIndirect (pDC, lphdi->i Image, point, 
size, CPoint(0 / 0) ) ; 



iwidth = m_sizelmage.cx; 



} 



return iwidth; 

} 

INT CFlatHeaderCtrl : :DrawBitmap (CDC* pDC, CRect rect, LPHDITEM lphdi, 
CBitmap* pBittnap, BITMAP* pBitmapInf o , BOOL bRight) 



{ 



INT iWidth = 0; 

if (pBittnap) 

iWidth = pBitmapInfo->bmWidth; 

if (iWidth<=rect. Width () && rect .Width () >0) 



{ 



bmHeight>>l) ; 



POINT point; 

point, y = rect. Center Point () .y - (pBitmapInf o-> 

if (bRight) 

point. x = rect -right - iwidth; 

else 

point. x = rect. left; 
CDC dc; 

if (dc.CreateCompatibleDC(pDC) == TRUE) 



{ 



(pBitmap) ; 



binHeight, 



CBitmap* pBitmapDC = (CBitmap*)dc.SelectObject 

ASSERT (pBitmapDC) ; 

iWidth = pDC->BitBlt( 

point. x, point. y, 

pBitmapInfo->bmWidth, pBitmapInf o-> 

&dc, 0, 0, SRCCOPY 
) ? iWidth: 0; 



dc . SelectObject (pBitmapDC) ; 
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else 

iWidth = 0; 

} 

else 

iWidth = 0; 

} 

return iWidth; 

} 

INT CFlatHeaderCtrl: :DrawText (CDC* pDC, CRect rect, LPHDITEM lphdi) 
{ 

CSize size; 

if (rect. Width ()>0 && lphdi ->mask&HDIJTEXT && lphdi-> 
fmt&HDFJSTRING) 

^ size = pDC->GetTextExtent ( lphdi ->pszText) ; 

switch ( lphdi - >f mt &HDF_JUSTIFYMASK) 
{ 

case HDF_LEFT: 

case HDF_LEFT|HDF_RTLREADING: 

pDC - >DrawText ( lphdi - >ps zText , - 1 , rect , 
DT_LEFT j DT_ENDJ3LLIPSIS | DTJSINGLELINE | DT_VCENTER) ; 
break; 

case HDF_CENTER: 

case HDF__CENTER | HDFJRTLREADI1TG : 

pDC- >DrawText ( lphdi - >ps zText , - 1 , rect , 
DT_CENTER | DT_END_ELL IPS I S | DT — S INGLEL INE | DT_VCENTER) ; 
break; 

case HDF_RIGHT : 

case HDF_RIGHT | HDFJRTLREADING : 

pDC->DrawText ( lphdi ->pszText, -1, rect, 
DT_RIGHT | DT_ENI)_ELLIPSIS | DT_S INGLELINE | DT_VCENTER) ; 
break; 



size.cx = rect. Width ()>size.cx ? size.cxrrect -WidthO ; 
return size.cx>0 ? size.cx:0; 

} 

INT CFlatHeaderCtrl: :DrawArrow( CDC* pDC, CRect rect, BOOL 
bSortAscending, BOOL bRight) 

^ INT iWidth « 0; 

if (rect. Width ()>0 && m_sizeArrow.cx<=rect .Width () ) 
^ iWidth = m_sizeArrow.cx; 

rect. top += (rect. Height () - m_sizeArrow.cy - 1)»1; 
rect. bottom = rect. top + m_sizeArrow.cy - 1; 

- rect. left = bRight ? rect. right -m_sizeArrow.cy: rect .left ; 

// Set up pens to use for drawing the triangle 
CPen penLight (PS_SOLID, 1, m_cr3DHighLight) ; 
CPen penShadow(PS_SOLID, 1, m_cr3DShadow) ; 
CPen *pPen « pDC->SelectObject (fcpenLight) ; 



119 



WO 03/010634 



PCT/US02/23713 



if (bSortAscending) 

// Draw triangle pointing upwards 

pDC->MoveTo(rect.left + ( (m_sizeArrow. cx-1) »1) + 1, 

rect. top) ; 

pDC->LineTo (rect . left + (m_sizeArrow. cx-1) , 
rect. top + m_sizeArrow.cy - 1) ; 

pDC->LineTo (rect . lef t , 

rect. top + m_sizeArrow.cy - 1) ; 

pDC->SelectObject (fcpenShadow) ; 

pDC->MoveTo( rect. left + ( (m_sizeArrow. cx-1) >>1) , 

rect. top) ; 

pDC- >LineTo (rect . left , 
rect. top + m_sizeArrow.cy - 1) ; 

else 

{ 

// Draw triangle pointing downwards 
pDC->MoveTo (rect .left + ( (m_sizeArrow.cx-l) >>1) +1, 
rect. top + m_s ize Arrow. cy - 1) ; 

pDC->LineTo (rect .left + (m_sizeArrow.cx-l) , 

rect. top) ; 

pDC->SelectObject (fcpenShadow) ; 

pDC->MoveTo (rect. left + ( (m_sizeArrow. cx-1) »1) , 
rect. top + m_sizeArrow.cy - 1) ; 

pDC- >LineTo (rect . left , 
rect .top) ; 

pDC->LineTo (rect .left + m_sizeArrow.cx, 

rect .top) ; 



// Restore the pen 
pDC->SelectObject (pPen) ; 

penLight . DeleteOb j ect ( ) ; 
penShadow.DeleteObject () ; 



return i Width; 



INT CFlatHeaderCtrl: :OnToolHitTest (CPoint point, TOOLINFO* pTI) const 

INT iResult = CHeaderCtrl: :OnToolHitTest (point, pTI) ; 
if(iResult l= -1) 

return iResult; 

HDHITTESTINFO hdhti; 
hdhti.pt = point;. 

iResult = : :SendMessage(GetSafeHwnd() , HDM_HITTEST, 0, (LPARAM) 
(fchdhti) ) ; 

if (iResult > -1) 

{ 

Get IternRect (iResult, &pTI->rect) ; 

pTI->cbSize = sizeof (TOOL INFO) ; 
pTI->hwnd = GetSafeHwndO ; 
pTI->uFlags = TTF_ALWAYSTIP ; 



120 



WO 03/010634 



PCT/US02/23713 



pTI->lpszText = LPSTRJTEXTCALLBACK ; 
pTI->uId = FLATHEADER_TT_MAGI C ; 

} 

return iResult; 

} 

/// / in in inn in iiiiiiiin iiinii) ilium a i in n 11 ii in n 1 1 ii i ii mi 

II CHeaderCtrl message handlers 

LRESULT CFlatHeaderCtrl::OnInsertItem(WPARAM wParam, LP ARAM lParam) 

^ HDITEMEX hditemex; 

hditemex. iMinWidth = 0; 
hditemex. iMaxWidth = -1; 

LRESULT IResult = -1; 

WORD wltems = m_arrayHdrItemEx. Get Size () ; 
wParam = wParam<= wltems ? wParam : wltems; 

try 

^ ra_arrayHdrItemEx.InsertAt (wParam, hditemex); 

IResult = Default (); 

if (IResult < 0) // Cleanup 

m_arrayHdrItemEx.RemoveAt (wParam) ; 

catch (CMemoryExcept ion* e) 

^ e->Delete(); 
} 

return IResult; 

} 

LRESULT CFlatHeaderCtrl : : OnDeleteltem (WPARAM wParam, LPARAM lParam) 

^ ASSERT ( (INT) wParam < m_arrayHdrItemEx.GetSize () ) ; 
m_arrayHdrItemEx.RemoveAt (wParam) ; 

return Def ault () ; 

} 

LRESULT CFlatHeaderCtrl ::OnSetImageList (WPARAM wParam, LPARAM lParam) 

CIraageList* plmageList; • 
plmageList = CImageList : :FromHandle ( (HIMAGELIST) lParam) ; 

IMAGE INFO info; ( 

if (pImageList->GetImageInf o (0 , &inf o) ) 

* m sizelmage.cx = info . rclmage . right - inf o. rclmage. left; 
nTsizelmage.cy = inf o . rclmage . bottom - info. rclmage. top ; 

} 

return Default (); 



121 



WO 03/010634 PCT/US02/23713 



LRESULT CFlatHeaderCtrl::OnSetHotDivider(WPARAM wParam, LPARAM iParam) 

if (wParam) 
{ 

HDHITTESTINFO hdhti; 
hc3hti.pt. x = LOWORD(lParam) ; 
hdhti. pt.y = HIWORD (IParam) ; 
ScreenToClient (&hdhti .pt) ; 

(fchdhti))- iHotIndex ° SendMessage (HDM^HITTEST, 0, (LPARAM) 

if (iHotlndex >= 0) 
{ 

HDITEM hditem; 

hdi tern, mask = HDI_ORDER; 

VERIFY (Get Item (iHotlndex, fchditem) ) ; 

m_iHotDivider = hditem. iOrder; 

CRect rectltem; 

VERIFY (GetltemRect (iHotlndex, rectltem) ) ; 
if (hdhti. pt.x > rectltem. CenterPoint () .x) 
m_iHotDivider++ ; 



} 

else 



} 

else 



tnJLHotDivider = -1; 



m_iHotDivider = (INT) IParam; 



RECT rect; 

GetClientRect (fcrect) ; 

INT iltems = GetltemCount () ; 

if (m_iHotDivider >= 0 && m_iHotDivider<=ilteras+l) 
if (m_pDropWnd == NULL) 

m_pDropWnd = new CFHDropWnd (m crHotDivider) ; 
if (mjpDropWnd) 

m_pDropWnd->Create (rect . bottom - rect . top) ; 

if (m_pDropWnd != NULL) 
POINT pt; 

pt.y = (rect. bottom-rect. top) /2; 
if (m_iHotDivide'r<iItems) 

GetltemRect (OrderToIndex (ra_iHotDivider) , &rect) ; 
pt.x = rect. left - 1; 



} 

else 

{ 



} 



GetltemRect (OrderToIndex (iltems -1) , &rect) ; 
pt.x = rect. right; 



ClientToScreen(&pt) ; 

mjpDropWnd- >SetWindowPos (pt . x , pt . y) ; 
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} 

else 

{ 

if (mjpDropWnd 1= NULL) 

^ mjpDropWnd- >DestroyWindow ( ) ; 
m_j)DropWnd = NULL; 

} } ' 

return (LRESULT) m_iHotDivider ; 

} 

LRESULT CFlatHeaderCtrl: :OnLayout (WPARAM wParam # LPARAM IParam) 

^ LPHDLAYOUT lphdlayout = (LPHDLAYOUT) 1 Par am; 

if (m bStaticBorder) 

~~ lphdlayout ->prc->right += GetSystemMe tries (SM_CXBORDER) *2; 

LRESULT IResult = CHeaderCtrl : : Def WindowProc (HDM_LAYOUT, 0, 
IParam) ; 

if (tnJLHeight > 0) 

lphdlayout- >pwpos->cy = ra_iHeigh.t; 

return IResult;. 

} 

BOOL CFlatHeaderCtrl : :OnToolTipNot if y(UINT nld, NMHDR *pNMHDR, LRESULT 
*pResult) 

^ TOOLTI PTEXT *pTTT = (TOOLTIPTEXT * ) pNMHDR ; 

if ( 

pNMHDR - > idFrom == (UINT) FLATHEADER_TT_MAGIC && 
i m^arravHdrltetnEx [mjLHotlndex] . strToolTip • IsEmpty ( ) 

) { 

USES_CONVERSION ; 

wesepy ( (WCHAR* ) pTTT- >lpszText , A2W ( (LPCTSTR) m_arrayHdrItemEx 

[m_iHotIndex] . strToolTip) ) ; 

pTTT->lpszText = pTTT->szText; 
return TRUE; 

} 

else 

return FALSE; 

} 

///////////////////////////////////////////////////////// /////////////// 

11,11 . « 

II CFlatHeaderCtrl message handlers 

void CFlatHeaderCtrl : : OnSysColorChange ( ) 

^ CHeaderCtrl : : OnSysColorChange ( ) ; 

m_cr3DHighLight = : :GetSysColor (O)L0R_3DHIGHLIGHT) ; 
m_cr3DShadow = :: Get Sys Color (COLOR_3DSHADOW) ; 
m_cr3DFace = : :GetSysColor (COLORJ3DFACE) ; 
m crText = : : Get Sys Color (COLORJBTNTEXT) ; 
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} 

LRESULT CFlatHeaderCtrl: :OnGetFont(WPARAM wParam, LPARAM IParam) 

{ 

return (LRESULT) m_f ont . m hOb j ect ; 

} 

LRESULT CFlatHeaderCtrl: :OnSetFont (WPARAM wParam, LPARAM IParam) 

{ 

LRESULT lResult = Default (); 

CFont *pFont = CFont : : FromHandle ( (HFONT) wParam) ; 
if (pFont) 

' { 

LOGFONT If; 

pFont - >Get LogFont ( &1 f ) ; 

m_f ont .DeleteObj ect ( ) ; 

m font . CreateFontlndirect (&lf ) ; 

} 

return lResult; 

} 

BOOL CFlatHeaderCtrl: :OnEraseBkgnd( CDC* pDC) 
{ 

return TRUE; 

} 

void CFlatHeaderCtrl: :OnPaint () 
{ 

CPaintDC dc(this); 
if (m bDoubleBuf f er) 

{ " 

CMeraDC MemDC(fcdc); 
DrawCtrl (&MemDC) ; 

} 

else 

DrawCtrl (&dc) ; . 

} 

UINT CFlatHeaderCtrl: :OnNcHitTest (CPoint point) 
{ 

m_hdhtiHotItem.pt = point; 
ScreenToClient (&m_hdhtiHotItem.pt) ; 

tn_iHotIndex = S endMe s s age (HDM_HITTEST , 0, (LPARAM) 
(&m_hdhtiHotItem) ) ; 

if (m iHotlndex >= 0) 

{ " 

HDITEM hditem; 

hdi tern, mask = HDI_ORDER; 

VERIFY (Get Item (m_iHot Index, fchditem) ) ; 

m_iHotOrder = hditem.iOrder; 

HDITEMEX hditemex; 

if (GetltemEx (m_iHotIndex, fchditemex) ) 
mjDHotltemResizable = 
hditemex . nStyle£HDF_EX_FIXEDWIDTH ? FALSE: TRUE; 

} 
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return CHeaderCtrl: :OnNcHitTest (point) ; 

} 

BOOL CFlatHeaderCtrl : :OnSetCursor (CWnd* pWnd, UINT nHitTest, UINT 
message) 

^ . if (m_iHotIndex>=0 m_hdhtiHotItem. flags* 
(HHT_ONDIVIDER | HHT_OND I VOPEN ) && lm_bHotIteniResizable) 

^ SetCursor ( Af xGetApp ( ) - >LoadSt andardCursor ( IDC_ARROW) ) ; 

return TRUE; 

} 

return CHeaderCtrl: : OnSet Cursor (pWnd, nHitTest, message); 



void CFlatHeaderCtrl : : OnLButtonDown (UINT nFlags, CPoint point) 

^ m_nClickFlags = nFlags; 
m_ptClickPoint = point; 

if (m_iHot Index >= 0) 
{ 

m hdiHot Item. mask = 
HDIJfflDTH | HDI~FORMAT | HDIJTEXT | HDI_IMAGE | HDI_BITMAP | HDI_ORDER I HDI_LPARAM; 
m_hdiHotItem.pszText = m_szHotItemText ; 
m_hdiHotItem.cchTextMax = sizeof (m_szHotItemText) ; 
VERIFY (Get Item (m_iHot Index, &m_hdiHotItem) ) ; 
VERIFY (GetltemEx (mjlHotlndex, &m_hdieH6tItera) ) ; 

if (m hdhtiHotltem.flags&HHT^ONHEADER) 
{ ~~ 

RECT rectltem; 

VERIFY (GetltetriRect (m_iHotIndex, fcrectltem) ) ; 
InvalidateRect (fcrectltem) ; 

} 

if (mJidhtiHotltem. f lags* (HHT^ONDIVIDER | HHT_ONDIVOPEN) ) 

^ if ( !m_bHotItemResizable) . 

return; 

HDITEMEX hditemex; 

VERIFY (GetltemEx (m_iHotIndex, fchditemex) ) ; 
CRect rectltem; 

GetltemRect (ro__iHot Index, rectltem) ; 
ClientToScreen (rectltem) ; 

if (hditemex. iMinWidth hditemex. iMaxWidth) 

^ CRect rectClip; 

GetClipCursor(rectClip) ; 

POINT point; 
GetCursorPos (fcpoint) ; 

INT iOffset = point. x - rectltem. right; 
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rectClip.left = rectltem. lef t + 
hditemex.iMinWidth + iOffset; 

rectClip . right = rect Item. lef t + 
hditemex . iMaxWidth + iOffset; 

ClipCursor (rectClip) ; 

} 

m_bResizing = TRUE; 

} 

} 

CHeaderCtrl : : OnLButtonDown (nFlags , point ) ; 

} 

void CFlatHeaderCtrl: :OnLButtonDblClk(UINT nFlags, CPoint point) 

if (ra_iHotIndex>=0 && mJfcidhtiHot Item, flags* 
( HHT_OND I VIDER | HHT__OND I VOPEN ) !m_bHotItemResizable) 
return ; 

CHeaderCtrl : : OnLButtonDblClk (nFlags , point ) ; 

} 

void CFlatHeaderCtrl: : OnLButtonUp (UINT nFlags, CPoint point) 

m_nClickFlags = nFlags; 
m_ptClickPoint « point; 

if (m_iHot Index >= 0) 

CWnd* pWnd = GetParent ( ) ; 

if (mjidht iHotl tern . f lags& ( HHT_OND IVTDER | HHT_OND I VO PEN ) ) 

if (m_bResizing) 

ClipCursor (NULL) ; 
ra bResizing = FALSE; 

} 

} 

if (m_hdhtiHotItem.f lagsfiBHT_ONHEADBR) 

if (m bDragging) 
{ 

NMHEADER nrahdr; 
nrahdr .hdr .hwndFrom = m__hWnd; 
nrahdr . hdr - idFrom = GetDlgCtrllD ( ) ; 
nrahdr -hdr. code = HDN_J2NDDRAG ; 
nrahdr. i I tern = m_iHot Index; 
nrahdr . iButton = 0; 
nmhdr.pitem = &m__hdiHo tit era ; 
if (pWnd->SendMessage(fM_NOTIFY, 0, (LPARAM) 
&nmhdr) ==FALSE && ra iHotDivider>=0) 

~ { 

INT iCount = GetltemCount () ; 
ASSERT (m_iHotOrder < i Count ) ; 
ASSERT (m iHotDivider <= iCount) ; 
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iCount) ; 



LPINT piArray = new INT [i Count *2] ; 
if (piArray) 

GetOrderArray ( (LPINT) piArray, 
for (INT i=0, j=0;i<iCount;i++) 



{ 



if (j ss m_iHotOrder) 
if ( 



<m_iHotDivider && i « m_iHotDivider-l) | 
=m_iHotDivider && i == m_iHotDivider) 

piArray [m_iHotOrder] ; 

piArray tj++l ; 



else 



&pi Array [iCount] ) ; 



} 

else 



(m_iHotOrder 
(m_iHotOrder> 

piArray [iCount+i] = 

piArray [iCount+i] = 

} 

SetOrderArray ( iCount , (LPINT) 
delete piArray ; 

Af xThrowMemoryException ( ) ; 



0) 



} 

else 
{ 



} 

if (m_pDragWnd != NULL) 

^ tn_j>DragWnd- >Des troyWindow ( ) ; 
m_pDragWnd = NULL; 

} 

if (GetCapture()->GetSafeHwnd() == GetSafeHwnd 

ReleaseCaptureO ; 

m_bDragging = FALSE; 
OnSetHotDivider (FALSE , ' -1) ; 

Invalidate () ; 



RECT rectltem; 

VERIFY (GetltemRect (m_iHot Index , fcrectltem) ) ; 
InvalidateRect (fcrectltem) ; 



CHeaderCtrl : :OnLButtonUp (nFlags , point) ; 

} 

void CFlatHeaderCtrl: :OnMouseMove (UINT nFlags, CPoint point) 
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if (m_nClickFlags&MK_LBUTTON && m_iHotIndex>=0) 



{ 



if (m_bResizing) 

CHeaderCtrl : : OnMouseMove (nFlags , point) ; 

if {m_hdhtiHotItem. f 1 ags &HHT_ONHEADER ) 



{ 



if (m bDragging) 

{ " 

if (mjpDragWnd != NULL) 



{ 



(rect. Height ()»1) ) 



CRect rect; 

m_pDragWnd->GetWindowRect (&rect) ; 

CPoint pt = point; 
ClientToScreen(fipt) ; 

pt.Offset(-(rect.Width()»l) , - 



m_pDragWnd->SetWindowPos ( 
fcwndTop, 
pt.x, pt.y, 

SWP__NOSIZE | SWP_SHOWWINDOW | SWP_NOACTIVATE 

); 



0 , (LPARAM) (fchdhti) ) 



rectltera) ) ; 
0 -x) 

LoadStandardCursor (IDC_ARROW) ) ; 



HDHITTESTINFO hdhti; 
hdhti. pt.x = point, x; 
hdhti. pt.y = point. y; 

INT iHotOrder = -1; 

INT iHotlndex = SendMessage (HDM_HITTEST, 

if (iHot Index >= 0) 
{ 

HDITEM hditem; 

hdi tern, mask = HDI_ORDER; 

VERIFY (Get Item ( iHotlndex > fchditem) ) ; 

iHotOrder = hditem. iOrder; 

CRect rectltem; 

VERIFY ( Get I temRect (iHotlndex, ■ 
if (hdhti.pt .x > rectltem. CenterPoint 

iHot Order ++; 
SetCursor (AfxGetApp () -> 
m_iDropResult = FHDR__ONHEADER ; 



} 

else 

{ 



pt = point; 
ClientToScreen(fcpt) ; 

if 



(ra hdieHotltem.nStyle&HDF EX PERSISTENT) 



SetCursor (Af xGetApp 0 -> 
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LoadStandardCursor <IDC_NO) ) ; m _iDropResult = 

FHDR_PERS I STENT ; 

else 

^ if ( ! (tnJiDropTarget && 

m_rcDropTarget . Pt InRect (pt ) ) ) 

1 if (mjaDontDropCursor) 

SetCursor 

( Af xGetApp ( ) - >LoadCursor (m_nDontDropCursor ) ) ; 

SetCursor 

(AfxGetApp 0 ->LoadStandardCursor (IDCJSTO) ) ; 

m_iDropResult = 



FHDRJDROPPED; 



} 

else 

1 SetCursor (AfxGetApp ( ) - > 



LoadStandardCursor (IDC_ARROW) ) ; m _iDropRes U lt = 



FHDR ONTARGET; 



} 



} 



} 

if (iHotOrder == m_iHotOrder || iHotOrder 
- tn_iHotOrder + l) iE otOrder = -1, 

if (iHotOrder 1= mjLHotDivider) 

OnSetHotDivider (FALSE, iHotOrder); 

} 

return ; 

ilse if (GetStyle()SEDS_DRAGDROP) 

^ INT iDragCX = GetSystemMetrics (SM_CXDRAG) ; 
INT iDragCY = GetSystemMetrics (SM_CYDRAG) ; 

CRect rectDrag( 

m_ptClickPoint .x-iDragCX, 

rn.ptCliclcPoint.y-iDragCY, ^ tclickPoiat . x+iD r ag OL, 
mjotClickPoint .y+iDragCY 

) / 



if ( ! rectDrag . Pt InRect (point) ) 

^ NMHEADER nmhdr; 

- nmhdr . hdr . hwndFrom = m__hWnd; 

nmhdr. hdr -idFrom = GetDlgCtrllD () ; 
nmhdr. hdr -code = HDN_BEGINDRAG; 
nmhdr. iltem = m_iHot Index ; 
nmhdr . iButton = 1; 
nmhdr. pitem = smJidiHotltera; 

BOOL bBeginDrag = TRUE; 



129 



WO 03/010634 



PCT/US02/23713 



CWnd* pWnd = GetParentO; 
if (pWnd != NULL) 

bBeginDrag =" pWnd->SendMessage 
(WMJSIOTIFY, 0, (LP ARAM) &nmhdr) == FALSE ? TRUE: FALSE ; 

if (bBeginDrag) 

ASSERT (mjpDragWnd == NULL) ; 
m_pDragWnd = new CFEDragWnd; 
if (m_pDragWnd) 

CRect rectltem; 
VERIFY (GetltemRect 



(m iHotlndex, rectltem) ) ; 



this, m_iHotIndex, &m_hdiHotItem) ; 



ClientToScreen( tree t Item) ; 
mjpDragWnd- >Create (rectltem, 

} 



BOOL bVisible « FALSE; 
if (m hDropTarget != NULL) 

{ " 

bVisible « : :GetWindowLong 
(m_hDropTarget, GWLJ5TYLE) &WS_VTSIBLE ? TRUE: FALSE; 

HWND hParent = : : GetParent 

(m_hDropTarget) ; 

if (bParent) 

bVisible = 

: :GetWindowLong(hParent, GWL_STYLE) &WS_VISIBLE ? TRUE : FALSE ; 

if (m_hDropTarget i = NULL && 

bVisible) 

VERIFY ( : : GetWindowRect 

(m_hDropTarget, mjrcDropTarget) ) ; 

else 

m rcDropTafget-SetRectEmptyO ; 

} 

SetCaptureO ; 
m_bDragging = TRUE; 



} 

void CFlatHeaderCtrl : :OnCancelMode ( ) 
{ 

CWnd: :OnCancelMode () ; 
if (m bDragging) 

{ " 

•mjiClickFlags = 0; 

if (m_j>DragWnd != NOLL) 

ra_pDragWnd->DestroyWindow() ; 
mjpDragWnd = NULL; 
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} 

if (GetCapture()->GetSafeHvmd() == GetSaf eHvmdO ) 
ReleaseCapture () ; 

m_bDragging = FALSE; 
OnSetHotDivider ( FALSE , - 1 ) ; 

Invalidate () ; 
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//////////////////////////////////////////////////////////////////////// 
//// 

/ / File : CFlatHeaderCtrl . h 

// Version: 1.0.6 

// 

// Author: Maarten Hoeben 

/ / E -mai 1 : hoeben@nwn . com 

// 

// . Specification of the CFlatHeaderCtrl and associated classes. 
// 

// This code may be used in compiled form in any way you desire. This 

// file may be redistributed unmodified by any means PROVIDING it is 

// not sold for profit without the authors written consent, and 

// providing that this notice and the authors name and all copyright 

// notices remains intact. 

// 

// An email letting me know how you are using it would be nice as 

well . 

// 

// This file is provided "as is" with no expressed or implied 
warranty. 

// The author accepts no liability for any damage/loss of business 
that 

// this product may cause. 

'uiiiiiiiiiiiiinuiiiiiiiiiuiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii 
mi 

#if ! defined (AFXJFIATHEADEROT 
_INCLUDED_) 

#define AFX FLATHEADERCTRL H 2162BEB4 A882_11D2_B18A_B294B34D6940 
INCLUDED^ 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

// FlatHeaderCtrl.h : header file 

// 

#include <afxtempl.h> 
#include <tchar.h> 



#define FLATHEADERJTEXT_MAX 80 
#define FLATHEADERJIT_MAGIC -13111971 

//////////////////////////////////////////////////////////////////////// 
///// 

// CFlatHeaderCtrl window 

class CFlatHeaderCtrl; 
class CFHDragWnd; 
class CFHDropWnd; 

// FlatHeader properties 

#def ine FH_PROPERTY_S PACING 1 
#def ine FH_PROPERTY_ARROW 2 
#define FH_PROPERTY_STATICBORDER 3 
#define FH_PROPERTY_D0NTDROPCURSOR 4 
#def ine FH_PROPERTY_DROPTARGET 5 
#define FH PROPERTY_ENABLETOOLTIPS 6 
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// FlatHeader drop result 
#define FHDR_DROPPED -1 
#define FHDR_ONHEADER 0 
#define FHDR_ONTARGET 1 
#def ine FHDR_PERS I STENT 2 

// Extended header styles 

#define HDF_EX_AUTOWIDTH 0x0001 

#def ine HDF_EX_INCLUDESORT 0x0002 

#define HDF^EXJFIXEDWIDTH 0x0004 

#define HDF_EX_TOOLTIP 0x0008 

#def ine HDF_EX_PERS I STENT 0x0010 

typedef struct _HDITEMEX 
{ 

UINT nStyle ; 
INT iMinWidth; 
INT iMaxWidth; 
CStr ing strToolTip ; 

_HDITEMEX() ': nStyle(O), iMinWidth ( 0) , iMaxWidth(-l) {}; 
} HDITEMEX, FAR* LPHDITEMEX; 
class CFlatHeaderCtrl : public CHeaderCtrl 
^ friend class CFHDragWnd; 

DECLARE_DYNCREATE (CFlatHeaderCtrl) 

// Construction 

public: 

CFlatHeaderCtrl 0 ; 

// Attributes 

PUbll °BOOL ModifyProperty(WPARAM wParam, LPARAM lParam) ; 

BOOL GetlteroExdNT iPos, HDITEMEX* phditemex) const; 
BOOL SetItemEx(INT iPos, HDITEMEX* phditemex); 

INT GetItemWidth(LPHDITEM lphdi, BOOL blncludeSort = FALSE) ; 

void SetSortColutnn(INT iPos, BOOL bSortAscending); 
INT GetSortColutnn(BOOL* pbSortAscending = NULL); 

INT GetDropResult 0 ; 

INT GetHeightO; 

void SetHeight(INT iHeight) ; 

// Overrides 

public: 

virtual -CFlatHeaderCtrl 0 ; 

virtual void DrawItem(LPDRAWITEMSTRUCT) ; T „ mTrpi?M - M . BOOL 
virtual void DrawItem(CDC* pDC, CRect rect, LPHDITEM Iphdx, BOOL 
bSort, BOOL bSortAscending) ; 

virtual int OnToolHitTest (CPoint point, TOOLINFO* pTI) const; 
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// ClassWizard generated virtual function overrides 
// { { AFX_VTRTUAL (CFlatHeaderCtrl) 
// } }AFX — VIRTUAL 

// Implementation 
protected: 

BOOL m_bDoubleBuffer; 

INT m_iSpacing; 

SIZE m_sizelmage; 

SIZE ni_s i z eArrow ; 

BOOL m_bStaticBorder; 

UINT nt_nDontDropCursor; 

HWND m_hDropTarget ; 

CRect m_rcDropTarget; 

INT m_iDropResult ; 

INT m_iHot Index; 

INT tnjLHotOrder; ■ 

BOOL m_bHotItemResizable; 

HDHITTESTINFO m_hdhtiHotItem; 

HDITEM mJtidiHotltem; 

HDITEMEX tnJidieHotltera; 

TCHAR m_szHotItemText [FLATHEADER_TEXT_MAX] ; 

BOOL m_bResizing; 

INT m_iHotDivider; 
COLORREF m_crHotDivider; 
CFHDropWnd* m_pDropWnd; 

BOOL m_bDragging; 
CFHDragWnd* m_pDragWnd; 

UINT ra_nClickFlags; 
CPoint m_ptClickPoint; 

BOOL m_bSortAscending; 
INT m_iSortColumn; 

CAr r ay < HDITEMEX, HDITEMEX > m__arrayHdr IteraEx ; 

COLORREF m_cr3DHighLight ; 
COLORREF tn_cr3DShadow; 
COLORREF ra_cr3DFace; 
COLORREF ra_crText; 

CFont m_font; 

INT m_iHeight; 

void DrawCtrl (CDC* pDC) ; 

INT Drawlmage (CDC* pDC, CRect rect, LPHDITEM hdi, BOOL bRight); 

INT DrawBitmap(CDC* pDC, CRect rect, LPHDITEM hdi, CBitmap* 
pBitmap, BITMAP* pBitmapInfo, BOOL bRight) ; 

INT DrawText (CDC* pDC, CRect rect, LPHDITEM lphdi) ; 

INT DrawArrow (CDC* pDC, CRect rect, BOOL bSortAscending, BOOL 
bRight) ; 

// Generated message map functions 
protected : 

// { { AFXJVISG (CFlatHeaderCtrl) 

afx_msg LRESULT Onlnsertltem (WPARAM wparam, LPARAM lparam) ; 
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afx msg LRESULT OnDeleteltem (WPARAM wparam, LPA ^ J**^' . 
afx msg LRESULT OnSetlmageList (WPARAM viparam, LPARAM lparam), 
afx-ms| LRESULT OnSetHotlivider (WPARAM «param LPAR^ lparam) ; 
afx'msg LRESULT OnLayout (WPARAM wparam, LPARAM lparam) ; 

afxjmsg void OnPaintO; 

afx msg void OnSysColorChange () ; 

afx~msg BOOL OnEraseBkgnd (CDC* pDC) ; . . . 

afx~msg void OnLButtonUp (UINT nFlags, CPoint point ; 
afxjmsg void OnMouseMove (UINT nFlags, CPoint point); 
afx_msg void OnCancelMode 0 ; 

afi 7 iK^SULT onSetFont (WPARAM wParam, LPARAM lParam] I; 
SjSI LRESULT OnGetFont (WPARAM wParam, LPARAM lParam) ; 
DECLARE _MESSAGE_MAP ( ) 

BOOL OnToolTipNotifytUINT nld, NMHDR *pNMHDR, LRESULT * P Result) ; 

}; 

, / ii,,u/////f///i/iiifti//uf/n/n///u/n/////t//nui/u/un//iu/i 
inn a . . 

// CFHDragWnd window 

#define FHDRAGWND_CLAS SNAME _T ( "MFCFHDragWnd" ) 
class CFHDragWnd : public CWnd 

// construction 
public: 

CFHDragWnd () ; 

// Attributes 
public: 

// Operations 
public: 

// overrrides 
protected : 

// Drawing 

virtual void OnDraw(CDC* pDC) ; 

// classWizard generated virtual function overrides 

/ / { { AFX_V IRTUAL (CFHDragWnd) 

protected: 

virtual void PostNcDestroy 0 ; 
//}}AFX_VIRTUAL 

// implementation 
public: 

tSSa SSSIJi-t rect. CFX.tH.aderCtrl. pFlatBeadTCtr!. 
INT iltem, LPHDITEM lphdiltem) ; 

Pr ° teC CFlatHeaderCtrl* m jpFlatHeaderCtrl ; 
INT m_iltem; 
LPHDITEM mJLphdiltem; 
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// Generated message map functions 
protected : 

// { {AFX_MSG (CFHDragWnd) 

afxjmsg void OnPaintO; 

af xjnsg BOOL OnEraseBkgnd (CDC* pDC) ; 

//}}AFX_MSG 

DECLARE MESSAGE MAP() 

}; 

//////////////////////////////////////////////////////////////////////// 
///// 

// CFHDropWnd window 

#define FHDROPWND_CLASSNAME _T ( "MFCFHDropWnd" ) 
class CFHDropWnd ; public CWnd 

{ 

// Construction 
public : 

CFHDropWnd (COLORREF crColor) ; 

// Attributes 
public : 

// Operations 
public : 

void SetWindowPos (INT x, INT y) ; 

// Overrrides 
protected : 

// Drawing 

// ClassWizard generated virtual function overrides 

// { { AFX_yiRTUAL (CFHDropWnd) 

protected: 

virtual void PostNcDestroy ( ) ; 
//}}AFX_VIRTUAL 

// Implementation 
public : 

virtual -CFHDropWnd ( ) ; 

virtual BOOL Create (INT iHeight) ; 

protected: 

CBrush m_brush; 
CRgn m_rgn; 

INT m_iHeigh.t; 

// Generated message map functions 
protected: 

/ / { { AFX _MSG ( CFHDropWnd) 

afx msg BOOL OnEraseBkgnd (CDC* pDC) ; 

//}Jafx_msg 

declare message_map() 

} ; 

//////////////////////////////////////////////////////////////////////// 
///// 
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//{{AFX INSERT_LOCATION} } , . 

// Microsoft Visual C++ will insert additional declarations immediately 

before the previous line. 

#endif / / ! defined (AFX_FLATHEADERCTRL_H_2162BEB4_A8 82JL1D2 
B18A B294B34D6940 INCLUDED^) 
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// FoldersView.cpp : implementation file 
// 

# include "stdafx.h" 
#include "player, h" 
#include " Folder sView.h" 
#include "NewFolderDialog.h" 
#include <libxml/tree.h> 
#include <vector> 
#include "PlayerDoc.h" 

#include "Windowsx.h" // for GET_X_LPARAM 
#include "Utils.h" 

#ifdef _DEBUG 

#def ine new DEBUG_NEW 

#undef THIS_FILE 

static char THIS_FILE[] = FILE ; 

#endif 

////////////////// iiiiiiiiiiiiiiiiiiiui ii ii ii mi 1 1 in ilium i m ii in 
inn 

II CFoldersView 

IMPLEMENT_DYNCREATE (CFoldersView, CTreeView) 
CFoldersView : r CFoldersView ( ) 

{ 
} 

CFoldersView : : -CFoldersView ( ) 

\ 



BEGIN_MESSAGE_MAP (CFoldersView, CTreeView) 
/ / { { AFX_MSG_MAP (CFoldersView) 

ON_C0MMAND ( ID_FILE_NEWFOLDER , OnFileNewf older) 
ON_NOTIFY_REFLECT ( TVN_SELCHANGED , OnSelchanged) 
ONJ&OTIFY_REFLECT (SM_RCLICK, OnRclick) 

ON_C0MMAND ( ID_FOLDERS_ADDMEDIAITEMS , OnAddMediaToFolder ) 
ON_COMMAND ( ID_FOLDERS_RENAMEFOLDER , OnRenameFolderFromCM) 
ON_COMMAND ( ID_FOLDERS_DELETEFOLDER , OnDeleteFolderFromCM) 
ON_NOTIFY_REFLECT (TVN_BEGINLABELEDIT , OnBeginlabeledit ) 
ON_C0MMAND ( ID_FOLDERS__NEWFOLDER , OnNewFolderFromCM) 
ON NOTIFY_REFLECT (TVN_ENDIiABELEDIT, OnEndlabeledit) 
/ 1 J} AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

//////////////////////////////////////////////////////////////////////// 
///// 

// CFoldersView drawing 

void CFoldersView: :OnDraw(CDC* pDC) 

^ CDocument* pDoc = GetDocument ( ) ; 
// TODO: add draw code here 

} 

/////////u////////////in/u//i///t///ni/////////tnm/i/////u//n// 
urn 

II CFoldersView diagnostics 
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#ifdef _DEBUG 

void CFoldersView: : Assert Valid () const 

^ CTreeView: : Assert Valid 0 ; 
} 

void CFoldersView: : Dump (CI>umpContext& dc) const 
^ CTreeView : : Dump ( dc ) ; 

#endif //_DEBUG 



/uuui//f//f//n////f/inf/fi/ui/////it/////utn/f///f///f///////ii/ 
1 1 1 1 1 



II CFoldersView message handlers 
void CFoldersView: :OnInitialUpdate () 
CTreeView : : Onlnit ialXJpdate ( ) ; 

// TODO: Add your specialized code here and/ or call the base class 
CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 

string cppstrLabel; 

xmlNodePtr node = pDoc->Get Folders () ; 

xmlNodePtr f older snode = node; 
for (foldersnode; 

foldersnode != NULL; 

folder snode = foldersnode ->next) { 

if (strcxnp(reinterpret_cast<const char *> (node->name) , 

"Folders") == 0) { 

AddFolderFromXML ( folder snode, NULL, true); 

} 

} 

if (GetTreeCtrl ( ) . GetRootltem ( ) I = NULL) 

GetTreeCtrl () .Expand (GetTreeCtrl .() .GetRootltem 
() ,TVE_EXPAND) ; 

SelectlnboxO ; 

m_oleDropTarget . Register (this) ; 

} 

BOOL CFoldersView: :PreCreateWindow(CREATESTRUCT& cs) 

^ // TODO- Add your specialized code here and/or call the base class 
CS Styl4 1= TVS HASLINES | TVS_LINESATROOT | TVSJIASBUTTONS | • 
TVS_SHOWSELALWAYS | TVS_EDITLABELS; 

return CTreeView: :PreCreateWindow(cs) ; 

} 

void CFoldersView : : OnFileNewf older ( ) 

^ // TODO: Add your command handler code here 
CNewFolderDialog folderDlg; 



139 



WO 03/010634 



PCT/US02/23713 



if (folderDlg.DoModaK) != IDOK) 
return; 

CString fName; 
xralNodePtr node; 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 
HTREEITEM hNewHTreeltem; 

fName = folderDlg.m_strNewFolderName; 
HTREEITEM hRoot = GetTreeCtrl () -GetRoot I tern () ; 

node = pDoc- >AddFolderToXML ( fName . operator LPCTSTRO); 
hNewHTreeltem = GetTreeCtrl () -Insertltem( (fName. operator LPCTSTR 
()) , hRoot) ; 

/*hNewTVItem.hItem = UNewHTRee Item; 
MewTVI tern . mask = TVIF_PARAM; 
hNewTVItem.lParam = (LPARAM) node ; */ 
• GetTreeCtrl ( ) . SetltemData (hNewHTreeltem, (DWORD) node) ; 

} 

HTREEITEM CFoldersView : : AddFolderFromXML (xmlNodePtr node, HTREEITEM 
hRoot, bool firstTime) 

// Pay attention. This is a recursive function call. It will add 

all 

// the folders inside of "folder" too. 

// firstTime should be true if you call it from OnlnitialUpdate 
// so it can set Inbox as the selected item. 

string strLabel; 
HTREEITEM tempTreeltem; 
xmlNodePtr folder = NULL; 

for (folder = node ^children- 
folder != NULL; 
folder = folder- >next) { 

if (strcmp(reinterpret_cast<const char *> 

( folder ->name) , 

"Folder") == 0) { 

//if (DEBUG) std::COUt « "DEBUG: Folder " 

<< folder- >name « endl; 

xmlChar *label; 

label = xmlGet Prop (folder, 

reinterpret_cast<const unsigned char 

*> 

("Label")) ; 
strLabel = reinterpret_cast<const char *> 

(label) ; 

tempTreeltem = GetTreeCtrl () .InsertI tern 

(strLabel. c str() , hRoot); 

~~ GetTreeCtrl ( ) . SetltemData (tempTreeltem, 

(DWORD) folder) ; 

if ( (firstTime) && (strLabel == "Inbox")) { 
inboxTreeltem « ten£>TreeItem; 

} 
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if (folder->children !« NULL) { 

//If the folder contains folders, 

do this again. _ , - ^ 

* AddFolderFromXML ( folder , 

tetnpTreeltem, f irstTime) ; 

} 

) 

return tempTreeltem; 

} 

void CFoldersView : : OnS el changed (NMHDR* pNMHDR, LRESULT* pResult) 

^ NM TREE VIEW* pNMTreeView = (NMJTREEVIEW* ) pNMHDR ; 

//~TODO: Add your control notification handler code here 
CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 
HTREEITEM selectedltera = GetTreeCtrl 0 .GetSelectedltem () ; 
if (selectedltem == NULL) { 
MessageBox ( "Huh? " , 

"Error", MB_OK) ; 

} 

xmlNodePtr folderNode ; 

// Get the nodePtr attached to the folder to add to. 

folderNode = (xmlNodePtr) GetTreeCtrl 0 .Get It emData( selectedltem) ; 

pDoc- >SetCurSelectedFolder (folderNode) ; 

TRACE ( "Folder Selection Set.\n"); 

*pResult = 0; 

} 

void CFoldersView: :OnRclick (NMHDR* pNMHDR, LRESULT* pResult) 
^ CTreeCtrl & tc = GetTreeCtrl () ; 

/* Get the mouse cursor position */ 
DWORD dwPos = GetMessagePos () ; 

/* Convert the co-ords into a CPoint structure */ 

CPoint pt( GET_X_LPARAM( dwPos. ), GETJTLPARAM ( dwPos ) ), spt; 

spt = pt; 

/* Convert to screen co-ords for hittesting */ 
tc.ScreenToClient ( &spt ); 

//Set rightClickPoint for hittesting on the treeview. 
rightClickPoint = spt; 

// Add Popup menu 
CMenu menu; 

VERIFY (menu . LoadMenu ( IDR_FOLDERS_MENU) ) ; 
CMenu* pPopup = menu.GetSubMenu(O) ; 
ASSERT (pPopup != NULL) ; 

pPopup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, pt.x, 
pt . y , Af xGetMainWnd ( ) ) ; 

*pResult = 0; 

} 
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void CFoldersView : : OnAddMediaToFolder ( ) { 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 

UINT flags; 

HTREEITEM selectedltem = GetTreeCtrl () .HitTest (rightClickPoint, 
&f lags) ; 

if (selectedltem «« NULL) { 

MessageBox("You must have a folder selected before you can 

add media. 11 , 

"Error" , MB__OK) ; 
return; 

} 

// Get the nodePtr attached to the folder to add to. 
xmlNodePtr parentNode = (xmlNodePtr) GetTreeCtrl () -GetltemData 
(selectedltem) ; 

if (parentNode == NULL) { 

MessageBox( "Error adding to folder.", 

"Error" ,MB_0K) ; 
return; 

} 

char filename [102400] ; 
filename [0] = 1 \0 1 ; 
OPENFILENAME ofn; 

memset (tofn, 0, sizeof (OPENFILENAME) ) ; 

ofn.lStructSize = sizeof (OPENFILENAME) ; 

ofn.hwndOwner = Af xGetMainWnd ( ) ->m_hWnd; 

ofn. Flags = OFN_ALLOWMULTISELECT | OFN_EXPLORER; 

ofn.lpstrFile = (LPSTR) filename ; 

ofn.nMaxFile » 102400; 

if (GetOpenFileName (&ofn) == 0) { 

// User canceled or closed the dialog box or an error 

occurred. 

//if (DEBUG) std::cout « "DEBUG: No File selected. \n" ; 
return; 

• }; 

int i = 0; 

vector<string> filenames; 
for (string file = &f ilename [i] ; 
f ile . compare ( n ") ; 
file = &f ilename [i] ) { 

i .+= file.lengthO + 1; 

//if (DEBUG) std::cout « "DEBUG: selected " « file << "\n"; 
f ilenames. insert (filenames. end () , file) ; 

if (filenames. size 0 == 1) { 

//if (DEBUG) std::COUt « "DEBUG: one selected\n" ; 

else { 

//if (DEBUG) std::COUt « "DEBUG: multiple selected\n"; 
for(unsigned int i=l; i<f ilenames. size () ; i++) { 

string full = filenames [0] ; 

full . append ( • \\ " ) ; 

full . append (filenames [i] ) ; 

filenames [i] = full; 
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typedef vector<string> :: iterator VI; 
VI vi; 

if (filenames. size () == 1) { 

vi = f ilenames. begin () ; 

} , 

else { 

vi s filenames. begin 0 + 1; 

for(; vi i= filenames -end() ; vi++) { 
pDoc->AddMediaToXML (parentNode , 

*(vi), 

"Local" , 
n _ it 

*(vi), 

CUtils: :get_currdatetime() , 

"local", 
"none") ; 

pDoc->UpdateAllViews (NULL) ; 

} 

void CFoldersView : : Selectlnbox ( ) 

{ if (inboxTreeltem != NULL) { // will never happen. Just being safe. 

GetTreeCtrK) .Selectltem( inboxTreeltem) ; 

} 

} 

void CFoldersView: :OnDeleteFolderFromCM() 

* CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 

HraEEITEM S selectedItem = GetTreeCtrl () .HitTest (rightClickPoint, 
fcflags) ; 

if (selectedltem == NULL) { , ^ 

MessageBox("You must click on a valid folder before you can 

delete a folder. ' n^rror" ,MB_OK | MB_ICONEXCLAMATION) ; 
return; 

} 

xmlNodePtr curNode ; 

// Get the nodePtr attached to the folder to add to. 

curNode = (xmlNodePtr) GetTreeCtrl () . GetltemData ( selectedltem) ; 

if ((curNode == P Doc->GetInboxNodePtr 0 ) || (curNode == pDoc-> 

GetTrashNodePtrO) ) { ^ _ _ « «. m„ e «u .. 

MessageBox("You can not delete the Inbox or the Trash. , 

"Error" ,MB_OK | MB_ICONEXCLAMATION) ; 
return; 

} 

if (MessageBoxO'Are you sure you want to permenantly delete this 
folder and all items in it? This will remove these files from your hard 
drive . " , 

"Confirm Folder Deletion", 

MB_YESNO | MB_ICONEXCLAMATION) 1 == IDNO) return; 
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SelectlnboxO ; 

// Remove the folder the user right clicked on. 
GetTreeCtrl ( ) .Deleteltem( select edltem) ; 
// Delete it from the xml structure. 
pDoc->DeleteFolder (curNpde) ; 

} 

void CFoldersView: : OriRenameFolderFromCM ( ) 

1 CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument ()) ; 

UINT flags; 

HTREEITEM selectedltem = GetTreeCtrl () .Hi tTest (rightClickPoint , 

&f lags) ; 

if (selectedltem == NULL) { 

MessageBox("You must select a valid folder. n , 

" Error ",MB_OK | NB_ICONEXCLAMATION) ; 
return; 

} 

GetTreeCtrl ( ) .EditLabel (selectedltem) ; 



void CFoldersView: : OnNewFolderFromCM ( ) 

* CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument ()) ; 

UINT flags ; 

HTREEITEM selectedltem = GetTreeCtrl () .HitTest (rightClickPoint , 

&f lags) ; 

if (selectedltem == NULL) { 

MessageBox("You must click on a valid folder before you can 

add new media. ", 

"Error" ,MB_OK | MB_ICONEXCLAMATION) ; 
return; 

} 



xmlNodePtr parentNode ; 

// Get the<nodePtr attached to the folder to add to. 

parentNode = (xmlNodePtr) GetTreeCtrl () .Get ItemData( selectedltem) ; 

if ( (parentNode pDoc->GetInboxNodePtr () ) || (parentNode == 
pDoc - >GetTrashNodePtr ( ) ) ) { 

MessageBox ( "You can not add a sub folder to the Inbox or the 

Trash • " 

"Error" ,MB_OK | MB_ICONEXCLAMATION) ; 
return; 

} 



CNewFolderDialog folderDlg; 

if (folderDlg.DoModalO 1= IDOK) 
return; 

CString fNarae; 
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xralNodePtr node; 

HTREEITEM hNewHTreeltem; 

fName = folderDlg.m_strNewFolderName; 

node = pDoc->AddFolderToXML (fName . operator LPCTSTRO , parentNode) ; 
hNewHTreeltem = GetTreeCtrl ( ) .Insertltem( (fName. operator LPCTSTR 

0) ' S GetTreeCtrl > ( ) . SetltemData (hNewHTreeltem, (DWORD) node) ; 
} 

void CFoldersView::OnBeginlabeledit(NMHDR* pNMHDR, LRESULT* pResult) 

^ TV DISPINFO* pTVDispInfo = (TV_DISPINFO*)pNMHDR; 

//~TODO: Add your control notification handler code here 
CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc * > (GetDocument ( ) ) ; 

if (pDoc->minbox(> || pDoc->InTrash() ) { 
♦pResult = 1; 

else { 

♦pResult = 0; 

} 

} 

void CFoldersView: :OnEndlabeledit(NMHDR* pNMHDR, LRESULT* pResult) 
{ 

TV DISPINFO* pTVDispInfo = (TV_DISPINFO*) pNMHDR; 
//~TODO: Add your control notification handler code here 

if (pTVDispInfo->item.pszText == NULL) return; 

SSrS^pDoc = reinterpret_cast< CT layerDoc*> (GetDocument ()); 
HTREEITEM curSelTreeltem = GetTreeCtrl 0 .GetSelectedltemO ; 
GetTreeCtrl 0 .SetltemText (curSelTreeltem, pTVDispInfo- > 

item.pszText) ; 

newName = pTVDispInfo->item.pszText; 

xralNodePtr curNode = pDoc->GetCurSelectedFolder O ; 

xmlSetProp(curNode, 

reinterpret cast<const unsigned char *>( "Label ), 
reinterpret>ast<const unsigned char *> (newName . c_str () ) ) ; 

♦pResult =0; 

} 

DROPEFFECT CFoldersView: :OnDragEnter (COleDataObject* pDataObject, DWORD 
dwKeyState, CPoint point) 

* CTreeView: :OnDragEnter (pDataObject, dwKeyState, point); 
return DROPEFFECTJJONE; 

} 

DROPEFFECT CFoldersView: :OnDragOver (COleDataObject* pDataObject, DWORD 

dwKeyState, CPoint point) 

{ 
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CTreeView: :OnDragOver (pDataObject, dwKeyState, point); 

// Verify a folder is available to drop into. 

/* 

-BEGIN- Find the folder to add to 

*/ 

/* Get the mouse cursor position */ 
DWORD dwPos = GetMessagePosO; 

/* Convert the co-ords into a CPoint structure */ 

CPoint pt( GET_X_LPARAM( dwPos ), GET_Y_LPARAM ( dwPos ) ), spt; 

spt = pt; 

/* Convert to screen co-ords for hittesting */ 
GetTreeCtrlO .ScreenToClient ( &spt ); 

UINT flags; 

HTREEITEM selectedltem = GetTreeCtrlO .HitTest (spt , &f lags) ; 
if (selectedltem — NULL) return DROPEFFECT_NONE ; 

// Get the nodePtr attached to the folder to add to. 
xmlNodePtr parentNode = 

(xmlNodePtr) GetTreeCtrl () .GetltetnData (selectedltem) ; 
if (parentNode == NULL) return DROPEFFECT_NONE ; 
/* 

-END- Find the folder to add to 

*/ 

// Verify the data is in an acceptable format. 

if (pDataObject->IsDataAvailable ( ( (CPlayerApp*) AfxGetApp () ) -> 
GetClipboardFormat ())) { 

return (dwKeyState & MK_CONTROL) ? 
DROPEFFECT_COPY : DROPEFFECT_MOVE ; 

else if (pDataObject->IsDataAvailable(CF_HDROP) ) { 
// Only Copy allowed on filenames 
return DROPEFFECT_COPY; 

} 

else 

return DROPEFFECTJJONE; 

} 

BOOL CFoldersView: :0nDrop (COleDataObject* pDataObject, DROPEFFECT 
dropEffect, CPoint point) 

CTreeView: :OnDrop (pDataObject, dropEffect # point); 

/* 

-BEGIN- Find the folder to add to 

. */ 

/* Get the mouse cursor position */ 
DWORD dwPos ss GetMessagePosO; 

/* Convert the co-ords into a CPoint structure */ 

CPoint pt( GET_X_LPARAM ( dwPos ), GET_Y_LPARAM ( dwPos ) ), spt; 

spt = pt; 

/* Convert to screen co-ords for hittesting */ 
GetTreeCtrl 0 .ScreenToClient ( &spt ); 

UINT flags; 
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0 



HTREEITEM selectedltem « GetTreeCtrl 0 .HitTest (spt , &f lags) ; 
if (selectedltem «» NULL) return false; 

// Get the nodePtr attached to the folder to add to. 
xmlNodePtr parentNode = , n ^ . 

(xmlNodePtr) GetTreeCtrl ( ) . GetltemData ( selectedltem) ; 
if (parentNode == NULL) return false; 

/* 

-END- Find the folder to add to 

*/ 

CPlayerDoc* pDoc = reinterpret_cast<CPlayerDoc *> (GetDocument () ) ; 
// See if an Episode is on the clipboard. 

UINT nFormat = ( (CPlayerApp*) AfxGetApp 0 ) ->GetClipboardFormat 

HGLOBAL hData « pDataOb j ect - >GetGlobalData (nFormat) ; 
if {hData 1= NULL) { 

typedef struct { xmlNodePtr x; } S; 

S* s = (S*) ::GlobalLock (hData); 

xmlNodePtr p = s->x; 

pDoc - >MoveNodeToFolderNode (p , parentNode ) ; 
: :GlobalUnlock (hData) ; 
::GlobalFree (hData); 
return TRUE; // Drop succeeded. 

} 

// see if bfilenames are on the clipboard. 
HDROP hDrop = (HDROP) P DataObject->GetGlobalData (CF_HDROP) ; 

if (hDrop ! = NULL) { 

// Find out how many file names the HDROP contains, 
int nCount = : :DragQueryFile (hDrop, (UINT) -1, NULL, 0) ; 
// Enumerate the file names, 
if (nCount) { 

TCHAR szFile [MAX_PATH] ; 

for (int i==0; i<nCount; i++) { 

: :DragQueryFile (hDrop, i, szFile, 
sizeof (szFile) / sizeof (TCHAR) ) ; 

pDoc- >AddMediaToXML (parentNode , 

szFile, 



} 



CUtils : :get_currdatetime () , 

^ pDoc->UpdateAllViews (NULL) ; 

!:GlobalFree (hDrop); 

return TRUE; // Drop succeeded. 

} 

return FALSE; // Drop failed. 



"Local", 
h _ n 

szFile, 



n _ ii 

9 

"local", 
"none") ; 
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#if ! defined ( AFX_FOLDERS VIEW__H_D3 1A5 3 5 9_A7 1E_4 0 2 1_8 7 1 2_ 
23131062A6FC INCLUDED^) 

#def ine AFX FOLDERSVTEW H D3 1A535 9_A7 1E_4 0 2 1_8 7 12_ 
23131062A6FC INCLUDED^ 

#if _MSC_VER > 1000 
#pragma once 

#pragma warning (disable: 4786) 
#endif // _MSC_VER > 1000 

#include <libxml/tree.h> 
#include <afxole.h> 

//////////////////////////////////////////////////////////////////////// 
///// 

// CFoldersView view 

class CFoldersView : public CTreeView 

{ 

protected: 

CFoldersView ( ) ; // protected constructor used by dynamic 

creation 

DECLARE_DYN*CREATE (CFoldersView) 

// Attributes 
public : 

// Operations 
public : 

void OnNewFolderFromCMO ; 

void SelectlnboxO ; 

HTREEITEM AddFolderFromXML (xmlNodePtr node, HTREEITEM hRoot, bool 
f irstTime) ; 

// Overrides 

// ClassWizard generated virtual function overrides 
/ / { { AFX_VIRTOAL ( CFoldersView) 
public : 

virtual void OnlnitialUpdate () ; 

virtual DROPEFFECT OnDragEnter (COleDataObject* pDataObject, DWORD 
dwKeyState, CPoint point) ; 

virtual DROPEFFECT OnDragOver (COleDataObject* pDataObject, DWORD 
dwKeyState, CPoint point) ; 

virtual BOOL OnDr op (COleDataObject* pDataObject, DROPEFFECT 
dropEffect, CPoint point) ; 

protected : 

virtual void OnDraw(CDC* pDC) ; // overridden to draw this 

view 

virtual BOOL PreCreateWindow(CREATESTRUCT& cs) ; 
//} } AFX_VI RTDAL 

// Implementation 
protected : 

virtual -CFoldersView () ; 
#ifdef _DEBUG 

virtual void AssertValidO const; 

virtual void Dump(CDumpContext& dc) const; 

#endif 

*77 Generated message map functions 
protected: 
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COleDropTarget m_61eDropTarget ; 

HTREEITEM inboxTreeltetn; 
CPoint rigbtClickPoint ; 

/ / { { AFX_MSG (CFoldersView) 

SHS^SS S3S32Sa& pNMHDR, LRESULT* pResult) ; 
a£"mS void OnRclick (NMHDR* pNMHDR, LRESULT* pResult) ; 
afx~msg void onAddMediaToFolder 0 ; 
afx~~msg void OnRenameFolderProtnCMU ; 

afx>sg void JJ^SSSSSSnti !««. LRESULT* pResult) ; 

. ScS -id >£n». ^ PResui t) ; 

//}}AFX_MSG 
DECLAREJMESSAGEJMAP ( ) 

V 'iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiimn 
urn 

{'/'KfS^'liU insert additional declarations Mediately 
before the previous line. 

#endif // Idefinea(AFX_FOLDERSVIE W _H_D31A5359_A71E_4021_8712_ 
2313 10 62A6FC INCLUDEDj 
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#if ! defined (GLOBALS_H) 
#def ine GLOBALS_H 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

#include <string> 
#include "stats.h" 
#include <libxml/tree.h> 
//#include "PlayerDoc.h" 

#define DECLAREJJSER_MES SAGE (name) \ 

static const UINT name = : :RegisterWindowMessage (name##_MSG) ; 

// Causes an UpdateAllViews ( ) in the MainFrm 
#define WM_USER_UPDATEALLVIEWS (WM_APP + 1) 
// Causes the MainFrm to update the progress bar 
//#define WM_USER_SET_PROGRESS (WM_APP + 2) 

#define WM_USER_SET_PROGRESS_MSG _T ( "WM_USER_SETJPROGRESS-9479553D-5D04- 
4409-A938-0BC263AAD56C") 

// Causes the Launch Media to be Enabled 
#define WMJtfSER_WMDLG_CLOSE (WM_APP + 3) 
// Causes media to be played. 
#define WM_USERJPLAY (WM_APP + 4) 

// Causes client to start downloaded content- Used by the timer thread . 
#define WM_USER_RECEIVE (WM_APP + 5) 

// Tells the Client that the download thread is done. 

#def ine WM_USER_DONEJDOWNLOAD (WM_APP + 6) 

// Message from System Tray Icon 

#define WM_USER_NOTIFYICON (WM_APP + 7) 

// Load URL in Browser View 

#define WM_USER_LOADURL (WM_APP + 8) 

// Indicate a new Instance will be needed 

#define WM_USERJDLDLG_CLOSE (WM_APP + 9) 

// Systray switch icon 

#define WM_USER_NOTIFYICON_ANIMATION_START (WM_APP + 10) 

#define WM_USER_N0TIFYICON_ANIMATION_CYCLE (WM_APP + 11) 

#define WM_USERJtfOTIFYICON_AOTMATION_END (WM_APP + 12) 

// Start syncronizer download. 

#define WMJJSER_STOP_DOWNLOAD (WM_APP +14) 

// Needed for sys tray icon animation. 

#define NUM_I CONS_IN_DL_ANIMATION 6 



static int iconResourceArray [NUM_ICONS_IN_DL_ J ANIMATION] = 

{ IDI_IC0N_DL_1, n)I_ICON_DL_2 , mi_IC0N_DL_3 , H>I_ICON_DL_4 , 

IDI ICON DL_5 , IDI_IC0N_DL_6 } ; 



//IP Address and port of Server. 
#define DEFAULT_IP _T( "207. 40 .106.22") 
#define DEFAULT_PORT _T("6666") 

// Cookie path. 

#define DEFAULT_COOKIE_PATH _T ( "/examples/ servlet/ n ) 
#endif 
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// HardDriveFullDlg.cpp : implementation file 
// 

#include "stdafx.h" 
#include "player. h» 
#include "HardDriveFullDlg.h" 

#ifdef _DEBUG 

#def ine new DEBUG_NEW 

#undef THIS_FILE ~ 

static char THIS_FILE[] = _FILE_; 
#endif v 

/l/ll /III/ /ll//ni///U////U//U/U/U//////////II//fff '/////////////// 
II CHardDriveFullDlg dialog 

CHardDriveFullDlg::CHardDriveFullDlg(CWnd* pParent /*=NULL*/) 
: CDialog (CHardDriveFullDlg : : IDD, pParent) 

^ // { {AFXJDATAJENIT (CHardDriveFullDlg) 

m_icon = : :LoadIcon(NULL,IDI_HAND) ; 
// :: Get Icon ( 

/ / } } AFXJDATA_INIT 

} 

void CHardDriveFullDlg: :DoDataExchange (CDataExchange* pDX) 

^ CDialog : : DoDataExchange (pDX) ; 

/ / { {AFXJDATAJMAP (CHardDriveFullDlg) 
/ / } }AFX_DATA_MAP 

} 

BEGIN MESS AGEJMAP (CHardDriveFullDlg, CDialog) 
"//{{AFX MSG MAP (CHardDriveFullDlg) 

ONJ3N_CL I CKED { IDC_SUGGESTIONS , OnSuggest ions ) 

//}}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

fi/tii // //it ///////////////if ui//ui/ff//u/////u/////////n///J/i//ti 

//^CHardDriveFullDlg message handlers 
void CHardDriveFullDlg: :OnSuggestions 0 

^ WinHelp (NULL) ; 
OnCancelO; 

} 
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#if ! defined ( AFX_HARDDRrraFULLDLG_H_8 C2 4 0 8 7D_F 672 _4 ECA_9BB 5_ 

7B6387610962 INCLUDED^) 

#def ine AFX_HARDDR3raFULLDLG_H_8C^^ 
INCLUDED^ 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

// HardDriveFullDlg.h : header file 

// 

//////////////////////////////////////////////////////////////////////// 
///// 

// CHardDriveFullDlg dialog 

class CHardDriveFullDlg : public CDialog 

{• 

// Construction 
public : 

CHardDriveFullDlg (CWnd* pParent = NULL); // standard constructor 

// Dialog Data 

// { {AFX_DATA (CHardDriveFullDlg) 
enum { IDD = IDD_HARDDRIVEFULL }; 
' / / } } AFX_D AT A 



// Overrides 

// ClassWizard generated virtual function overrides 
// { {AFX_VIRTUAL (CHardDriveFullDlg) 
protected : 

virtual void DoDataExchange (CDataExchange* pDX) ; // DDX/DDV 
support 

/ / } } AFX_VTRTUAL 

// Implementation 
.protected: 

// Generated message map functions 
/ / { {AFX_MSG (CHardDriveFullDlg) 
afx msg void OnSuggestions <) ; 
//}7afxjmsg 
declare_message_map ( ) 
private : 

HI CON m icon; 

h 

// { {AFX_INSERT_LOCATION} } 

// Microsoft Visual C++ will insert additional declarations immediately 
before the previous line. 

#endif // !def ined(AFX_HATODR:nreFUI^ 
7B6387610962 INCLUDED ) 
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#include "stdafx.h 11 
#include "ItemData.h" 
#include <sac.h> 

T SisSirLsssTSSfr-i. <«.. «b. »*. <**>, 

0x9f, 0x9 } }; 

static const BYTE bCertlnf oEx_App [] = . 
TSooToxOl, 0X02, 0X03, 0X04, 0x05, 0x06, 0x07, 0x08, 0x09 }; 

static const BYTE bCertlnfoEx SP [] = ^ 
{ ix09?^x08, 0X07, 0X06, 0^05, 0x04, 0x03, 0x02, 0x01, 0x00 
1 o5)9, 0X08, 0X07, 0X06, 0x05, 0x04, 0x03, 0x02, 0x01, 0x00 }; 

typedef struct { 

HRESULT hr; 

DWORD cbCert; 

BYTE pbCert [1] ; 
} CERTINFOEX; 

CItemData : : CItemData ( ) { 
m_f IsDevice = true; 

// Shared Device/Storage Members 
tnjpStorageGlobals = NULL; 
m_j>EnumStorage = NULL; 
m_szName [0] = 0; 

"// Device -Only Memebers 
rajpDevice = NULL; 
m_j>RootStorage = NULL; 

5l52^ si 2 eof(nL.SerialNumber), 0) ; 

m_szMfr[0] = 0; 
mjiwVersion =0; 
m_dwPowerSource ■ 0; 
m_dwPercentRemaining = 0; 
mjilcon = NULL; 
m_dwMemSizeKB = 0; 
m_dwMemBadKB = 0; 
m_dwMemFreeKB = 0; 
m_fExtraCertif ied = false; 

// Storage -Only Memebers 
mjpStorage = NULL; 

m dwAttributes =0; t i%\ 

FlllMeraory((void*)&m_Format, sizeof (mJ?ormat) , 0); 
FillMemory((void*)&m_DateTime, sizeof (m_DateTime) , 0) ; 
m_dwSizeLow =0; 
m_dwSizeHign = 0; 

} 

CItemData : : -CItemData ( ) { 
if (mjilcon) { 

DestroyIcon(m_JiIcon) ; 
m_hIcon = NULL; 

} 



if (mpStorageGlobals) { 

m _j>StorageGlobals->Release() ; 
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mjpStorageGlobals = NULL; 

if (injpEnumStorage) { 

mj?EnumStorage->Release () ; 
mjpEnumStorage = NULL; 

if (mjpRoot Storage) { 

mj?RootStorage->Release () ; 
m_pRoot Storage = NULL; 

if (m_pStorage) { 

mjpStorage->Release () ; 
mjpStorage = NULL; 

if (tnjpDevice) { 

mjDDevice- >Release ( ) ; 
mpDevice = NULL; 

} 

} 

bool CltemData: :Init (CWMDM* pWmdm) { 
mjpWmdm = pWmdm; 

return true; 

} 

bool CltemData: :Init (IWMDMDevice* pDevice) { 
HRESULT hr; 
WCHAR wsz [MAX_PATH] ; 
ULONG ulFetched; 

// This is a device object 
m_fIsDevice = true; 

// Shared Device /Storage Memebers 

// Get the RootStorage, StorageGlobals and EnumStorage interfaces 
mjpRoot Storage = NULL; 
mjpEnumStorage = NULL; 
m_j>StorageGlobals = NULL; 

IWMDMEnumStorage* pEnumRootStorage; 

hr = pDevice->EnumStorage(&pEnumRootStorage) ; 
if (hr != S_OK) return false; 

hr = pEnumRootStorage- >Next(l, &tnj>RootStorage , fculFetched) ; 
if (hr != S_0K) return false; 

hr = mjpRootStorage->GetStorageGlobals (&m_pStorageGlobals) ; 
if (hr != S_0K) return false; 

hr = mjpRootStorage->EnumStorage(&mj)Enx2mStorage) ; 
if (hr != 3 JDK) return false; 

pEnuinRootStorage->Release () ; 

} 

// Get Device Name 

hr = pDevice->GetName(wsz, sizeof (wsz) / sizeof (WCHAR) - 1) ; 
if(hr 1= S_OK) lstrcpy(ra_szName, nn ); 
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else WideCharToMultiBytetCP^ACP, 0L, wsz, -1, m^szName, sizeof 

(m szName) , 

"~ NULL, NULL) ; 

// Device-Only Members 

// Set the Device Pointer and addref it 
m_pDevice = pDevice; 
m_j>Device- >AddRef ( ) ; 

// Get Device Type 

hr = pDevice->GetType(&m_dwType) ; 

if (hr != SJDK) mjiwType = 0L; 

// Get Device Serial Number 
BYTE abMAC [SAC_MAC_LEN] ; 
BYTE abMACVerif y [SAC_MAC_LEN] ; 
HMAC hMAC; 

hr = pDevice^GetSerialNumberf&m^SerialNutnber, (BYTE*) abMAC) ; 

if (hr == S OK) { 

m pTtodm->mjaSAC->MACInit(&hMAC) ; 

m pWmcta->mjpSAC->MACUpdate(hMAC, 

iu_j^ (BYTE*) (&m_SerialNumber) , 

sizeof (m_SerialNumber) ) ; 
m pWmdm->m^SAC->MACFinal (hMAC, ^*i^^ ri ^ } ; 
if(memcmp (abMACVerif y, abMAC, sizeof (abMAC) ) ! = 0 

FillMemory((void*)&m_SerialNuTuber # sizeof (m_SenalNumber) , 0), 

} 

// Get Device Manufacturer , . . /wrwap^ - 1) • 

hr = P Device->GetManufacturer(wsz, sizeof (wsz) /sizeof (WCHAR) 1) , 

if (hr != S OK) lstrcpy(m_szMfr,«") ; si2eo f 
else wideCharToMultiBytetCP^ACP, 0L, wsz, -1, m^szMfr, sizeof 

(m szMfr) , ^ . 

- NULL, NULL) ; 

// Get Device Version b 

hr = pDevice->GetVersion(&m_dwVersion) ; 

if (hr i= S_OK) mjiwVersion = Oxffff; 

GetPower ( ) ; 

// Get Device Icon 

hr - P Device->GetDeviceIcon((ULONG*) &m_hIcon); 
if (hr != S_0K) mjilcon = NULL; 

GetSpace ( ) ; 

// Call opaque command to exchange extended authentication info 

^ HMAC hMAC; 

OPAQUECOMMAND Command; 

SS^Sf (bCertlnf oExApp) /sizeof (bCertlnf oExApp 

101 5 DWORD cbData SP = sizeof (bCertlnf oEx.SP) /sizeof (bCertlnf oEx_SP [0] ) ; 
Son cStalSend = sizeof (CERTINPOEX) + cbData.App; 

// Fill out opaque command structure ^/rrrrnM . 

iemSy( & (Coitm,Ld\guidCot n mand), SguidCertlnfoEx, S1 zeof (QUID) ) ; 
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Command . pData » (BYTE* ) CoTaskMemAlloc ( cbData_Send) ; 
if ( ! Command . pData) return false ; 

Command. dwDataLen = cbData_Send; 

// Map the data in the opaque command to a CERTINFOEX structure, and 
// fill in the cert info to send 
pCertlnfoEx = (CERTINFOEX*) Command. pDat a; 
pCertlnf oEx->hr = S_OK; 
pCertlnfoEx- >cbCert = cbData_App; 

memcpy(pCertInfoEx->pbCert / bCertInfoEx_App, cbData_App) ; 
// Compute MAC 

TmjpWmdm->m_pSAC->MACInit (&hMAC) ; 

mjpWmdm- >m_pSAC- >MACUpdate (hMAC, (BYTE*) (& (Command. guidCommand) ) , 

sizeof (GUID) ) ; 

mjpWmdm- >mjpSAC- >MACUpdate (hMAC, (BYTE*) (& (Command. dwDataLen) ) , 

sizeof (Command . dwDataLen) ) ; 

if ( Command. pDat a) 

m_pWmdm- >mjpSAC- >MACUpdate (hMAC , Command . pData , 
Command. dwDataLen) ; 

mjpWmdm- >mjpSAC- >MACFinal (hMAC , Command . abMAC) ; 

// Send the command 

hr = pDevice - >SendOpaqueCommand ( &Command) ; 
if (hr == S_OK) * { 

BYTE abMACVerif y [WMDM_MAC_LENGTH] ; 

// Compute MAC 

m_pWmdm»>mj)SAC->MACInit (&hMAC) ; 

m_pWmdm- >m_pSAC- >MACUpdate (hMAC, (BYTE*) (& (Command. guidCommand) ) , 
sizeof (GUID) ) ; 

m_pWmdm- >mjpSAC- >MACUpdate (hMAC , (BYTE* ) ( & (Command . dwDataLen) ) , 

sizeof (Command. dwDataLen) ) ; 

if (Command. pData) 

mjpWmdm- >mjp SAC - >MACUp date (hMAC , Command . pData , 
Command. dwDataLen) ; 

m_pWmdm->mjpSAC->MACFinal (hMAC, abMACVerif y) ; 

// Verify MAC matches 

if (meracmp (abMACVerif y, Command . abMAC , WMDM_MAC_LENGTH ) == 0) { 
// Map the data in the opaque command to a CERTINFOEX structure 
pCertlnfoEx = (CERTINFOEX*) Command. pDat a; 

//In this simple extended authentication scheme, the callee must 

// provice the exact cert info 

if ( (pCertlnfoEx- >cbCert != cbData_SP) || 

(raemcmp(pCertInfoEx->pbCert, bCertInfoEx_SP, cbData_SP) ==0)) 
m_fExtraCertified = true; 

if ( Command. pDat a) CoTaskMemFree ( Command. pData) ; 

} 

// Storage-Only Members (pointers/handles only) 
m_pStorage = NULL; 

return S OK; 

} 

bool CIteniData: :Init (IWMDMStorage* pStorage) { 
HRESULT hr; 
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WCHAR wsz [MAX_PATH] ; 

// This is a storage object 
m_f IsDevice = false; 

// Shared device/ storage members 

// Get a pointer to the StorageGlobals interface 

hr = pStorage->GetStorageGlobals(&mjpStorageGlobals) ; 

if (hr 1= S_OK) return false; 

// Get the storage attributes 

hr = pStorage->GetAttributes(&m_dwAttributes / &m_Format) ; 
if (hr != S_OK) m_dwAt tributes = 0; 

// Get a pointer to the EnumStorage Interface 
if (m_dwAttributes * WMDM_FILE_ATTRJFOLDER) { 

hr = pStorage- >EnumStorage ( SmjEnumStorage ) ; 

if (hr != S_OK) return false; 

} 1CTmT 
else m_jpEnumStorage = NULL; 

// Get the storage name 

hr = pStorage->GetName(ws Z/ sizeof (wsz) /sizeof (WCHAR) - 1) ; 
if(hr != S_OK) lstrcpy (m_szName, nM ); 

else WideCharToMultiByte(CP_ACP, 0L, wsz, -1, m_szName, sizeof 
(m szName) , 

NULL, NULL) ; 

// Device-Only Members (pointers/handles only) 
mjpDevice = NULL; 
rnj>RootStorage « NULL; 
mJbLlcon = NULL; 
m_fExtraCertif ied = false; 

// Storage -Only Members 

// Save the WMDM storage pointer 
m_pStorage » pStorage; 
m jpS torage - >AddRef ( ) ; 

// Get the storage date 

hr = pStorage ->GetDate (&m_Dat eTime) ; _ 
if(hr != S_OK) FillMemory( (void*)&mJDateTime / sizeof (m_DateTime) , 0); 

//If the storage is a file, get its size 

//If the storage is a folder, set the size to zero 

mjiwSizeLow « 0; 

m dwSizeHigh = 0; , _ 
if (! (m dwAttributes & WMDM_FILEJlTTR_FOLDER) ) 

hr =~pStorage->GetSize(&m_dwSizeLow, &m_dwSizeHigh) ; 

return true; 

} 

void CItetnData : : GetSpace ( ) { 

// Get the total, free and bad space on the storage 
HRESULT hr; 
DWORD dwLow; 
DWORD dwHigh; 
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m_dwMemSizeKB = 0; 

hr = m_pStorageGlobals->GetTotalSize(&dwLow / fcdwHigh) ; 
if (hr == S_OK) { 

INT64 nSize = ( (INT64)dwHigh « 32 | (INT64) dwLow) >> 10; 

m dwMemSizeKB = (DWORD) nSize; 
} ~ 

m_dwMemB adKB = 0; 

hr = mjpStorageGlobals->GetTotalBad(&dwLow, fcdwHigh) ; 
if (hr == S_OK) { 

INT64 nSize = ( (INT64) dwHigh « 32 | (INT64) dwLow) » 10; 

m dwMemBadKB = (DWORD) nSize; 
} " 

m_dwMemFreeKB = 0; 

hr » m_pStorageGlobals->GetTotalFree (fcdwLow, fcdwHigh) ; 
if (hr == S_OK) { 

INT64 nSize « ( (INT64)dwHigh « 32 | (INT64)dwLow) >> 10; 

m dwMemFreeKB = (DWORD) nSize; 



void CItemData: :GetPower () { 

// Get power source and power remaining. 
HRESULT hr; 

hr = m_pDevice->Get Power Source (&m_dwPowerSource, 
&m_dwPercentRemaining) ; 
if (hr i= S_OK) { 

ra_dwPowerSource = 0; 

m_dwPercentRemaining = 0; 



HRESULT CItemData; : Refresh () { 

if ( !m_fIsDevice) return E_ UNEXPECTED ; // Only valid for a device 

GetPower ( ) ; 
GetSpace ( ) ; 

return S_OK; 

} 
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#if -defined (AFX_ITOMDATA_H_722DB86F_B723_4531_8C94_9B042E87F2D4 



#if _MSC_VER > 1000. 
#pragma once 

#endif // _MSC_VER > 1000 

#include "wrndtruh" 
#include <mswmdm.h> 

class ClteraData { 
public: 

ClteraData 0 ; 

virtual -ClteraData 0 ; 

bool Init(IWMDMDevice* pDevice) ; 

bool Init (IWMDMStorage* pStorage) ; 

bool Init (CWMDM* pWmdm) ; 

HRESULT RefreshO; 

bool m_fIsDevice; // Flag indicating a device or storage 

// Shared Device/ Storage Members 
IWMDMStorageGlobals* m_pStorageGlobals ; 
IWMDMEnumStorage* m_j>EnumStorage ; 
char m_szName [MAX_PATH] ; 
CWMDM* m_j>Wmdm; 

// Device-Only Members 
IWMDMDevice* mjpDevice; 
IWMDMStorage* mj>Root Storage ; 
DWORD mjiwType; 
WMDMID m_SerialNumber; 
CHAR m_szMf r [MAX_PATH] ; 
DWORD m_dwVersion; 
DWORD m_dwPowerSdurce; 
DWORD m_dwPercentRemaining; 
HICON mjilcon; 
DWORD m_dwMemSizeKB ; 
DWORD m_dwMemBadKB; • 
DWORD m_dwMemFreeKB; 
bool m_fExtraCertified; 

// Storage-Only Members 
IWMDMStorage* mjpStorage; 
DWORD m_dwAttributes; 
_WAVEFORMATEX m_Format ; 
WMDMDATETIME m_DateTime ; 
DWORD mjlwSizeLow; 
DWORD m dwSizeHigh; 



private : 

void GetSpaceO ; 
void GetPowerO ; 

}; 

#endif // ! defined (AFX - ITEMDATA^H_722DB86F.B723_4531 - 8C94_9B042E87F2D4 
INCLUDED ) 
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// Login. cpp : implementation file 
// 

#include "stdafx.h" 
#include "player. h" 
#include "LoginDlg.h" 

#ifdef JDEBUG 

#def ine new DEBUG_NEW 

#undef THISJFILE 

static char THIS_FILE[] = FILE ; 

#endif 

//////////////////////////////////////////////////////////////////////// 
///// 

// CLoginDlg dialog 



CLoginDlg: : CLoginDlg (CWnd* pParent /*=NULL*/) 
: CDialog (CLoginDlg : :IDD, pParent) 

^ / / { {AFX_DATA_INIT (CLoginDlg) 

m_username = _T("") ; 
m_password = jr( nn ) ; 
/ / } }AFX_DATA_INIT 

} 



void CLoginDlg: :DoDataExchange (CDataExchange* pDX) 

^ CDialog : : DoDataExchange (pDX) ; 

/ / { {AFXJDATA_MAP ( CLoginDlg) 
DDX_Text(pDX, IDCJEDIT1, m_username) ; 
DDX_Text(pDX, IDC_EDIT2, mjpas sword ) ; 
/ / } }AFX_DATA_MAP 

} 



BEGIN_MESSAGE_MAP (CLoginDlg, CDialog) 

/ / { {AFX_MSG_MAP (CLoginDlg) 

// NOTE: the ClassWizard will add message map macros here 

//} }AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 If I H HI HI till llll 

urn 

II CLoginDlg message handlers 
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#if ! defined (AFX_LOGIN_H_FC744D64^0506_4E29_BDA4_E7C8BFA3AE91 

#defin^ 

#if J4SC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 
// Login. h : header file 
// 

urn 

II CLoginDlg dialog 

class CLoginDlg : public CDialog 

// Construction 

PUbllC CLoginDlg(CWnd* pParent = NULL); // standard constructor 

// Dialog Data 

/ / { { AFX__DATA ( CLoginDlg) 
enum { IDD = IDD_LOGIN_DLG }; 
CString m_username; 
CString m_password; 
/ / } } AFX_D AT A 

// Overrides . . a 

/ / ClassWizard generated virtual function overrides 

/ / { {AFX_VTRTUAL (CLoginDlg) 

SirtSai e 5oid DoDataExchange(CDataExchange* pDX) ; // DDX/DDV 

support 

/ / } }AFX_VIRTUAL 

// Inclement at ion 
protected: 

// Generated message map functions 

//{(AFX MSG (CLogiilDlg) , * 

17 NOTE: the ClassWizard will add member functions here 

//}}AFX_MSG 
DECLARE_MESSAGE_MAP ( ) 

}; 

^ { iffi^S^fiuS?iui iaaert additional deciaratioas irately 
before the previous line. 

#endif // ! defined (AFX_LOGIN_H__FC744D64_0506_4E29_BDA4_E7C8BFA3AE91 
INCLUDED _) 
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#include "stdafx.h" 

#include "player. h" 

#include "MainFrm.h" 

#include "DisplayView.h" 

#include " Folders View. h n 

#include "PlayerDoc . h" 

#include "HardDriveFullDlg.h" 

#include "globals .h n 

#include "Windowsx.h" // for GET_X_LPARAM 



#ifdef JDEBUG 
#define new DEBUG_NEW 
#undef THIS_FILE 

static char THIS_FILE [] = FILE ; 

#endif 

//////////////////////////////////////////////////////////////////////// 
///// 

// CMainFrame 

IMPLEMENTJDYNCREATE ( CMainFrame , CFrameWnd) 

DECLARE_USER_MESSAGE ( WM_USER_SET_PROGRESS ) 

BEGIN_MESSAGE _MAP ( CMainFrame , CFrameWnd) 
/ / { {AFX_MSG_MAP. (CMainFrame) 
ON_WM_CREATE ( ) 

ONJ4ESSAGE ( WM_USER_UPDATEALL VIEWS , OnMyUpdateMessage) 

ON_REGISTERED_MESSAGE ( WM_US ER_SET_PR0 GRES S , OnSetProgress ) 

ON_MESSAGE ( WM_USER_RECE IVE , OnReceiveMessage ) 

ON_ MESSAGE ( WM_USER_STOP_DOWNLOAD , OnStopDownload) 

ON_MESSAGE ( WM_USER_DONE_TOWNLOAI) , OnDoneDownl oad ) 

ON_MESSAGE(WMJJSER_NOTIFYICON, OnNotifylcon) 

ONJ4ESSAGE (WM_USERJSOTIFYICON_ANIMATION_START , 
OnNotifylconAnimationStart) 

ON_MESSAGE ( WM_USER_NOTIFYICON_ANIMATION_CYCLE , 
OnNo t i f y I conAnimat ionCycl e ) 

ON_MESSAGE (WM_USER_NOTIFYICON_ANIMATION_END , 
OnNotifylconAnimationEnd) 

ON_WM_CLOSE() ' 

ONJ4ESSAGE(WMJJSER_PLAY, OnPlay) 
ONJ4ESSAGE(WMJtfSER_LOADURL, OnUserLoadURL) 
ON_MESSAGE (WM_USER_WMDLG__CLOSE, OnWMDlgClose) 
ON_MESSAGE ( WM_USER_DLDLG_CLOSE , OnDlDlgClose ) 
ON_WM_TIMER() 

ON_COMMAND ( ID_TOOLS_RECEIVE , OnToolsReceive ) 
ON COMMAND ( ID_SYNC_STATUS , OnSyncStatus) 
//7}AFX_MSG_MAP 
END_MESSAGE_MAP ( ) 

static UINT indicators!] = 

ID_SEPARATOR, // status line indicator 

ID_INDICATOR_CAPS , 
ID_INDICATOR_NUM , 
ID_INDICATOR_SCRL , 

}; 



void CALLBACK EXPORT DLTiraerProc ( 
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HWND hWnd, // handle of CWnd that called SetTimer 

UINT nMsg, * // WMJTIMER 

UINT nIDEvent, // timer identification 

DWORD dwTime // system time 

) { 

: :PostMessage (hWnd, WM_USER_RECEIVE, (LPARAM) 0 , (WPARAM) 0) ; 
TRACE ("DL Timer callback called. \n n ) ; 

//// iiiii 1 1 ii 1 1 nun iiiiiiiiiiiiiiiiiuiiiiiiiiiiini i in mi iiiiiiim 
i 1111 «. - 

// CMainFrame construction/destruction 
CMainFrame: : CMainFrame ( ) 

^ m_displayView = NULL; , 
m_foldersView = NULL; 
m^webView = NULL; 
mjrrviewer = NULL; ^ 
m_syncStatusDlg = NULL; 
m_iconAnimationCount = 0; 

} 

CMainFrame : : -CMainFrame () 

\ 

int CMainFrame : :OnCreate (LPCREATESTRXJCT lpCreateStruct) 

^ if (CFrameWnd: :OnCreate( lpCreateStruct) == -1) 

return -1; 

// if (Im^wndToolBar-CreateExfthis, TBSTYLEJfLAT, WS^CHILD | 

WS VISIBLE CBRS TOP t 
//*" | CBRSJ3RIPPER | CTRS_TOOLTIPS | CBRS JFLYBY [ 

CBRS SIZE DYNAMIC) | | 

1 1 7 " l m_*mdToolBar .LoadToolBar ( IDR_MAINFRAME ) ) 

// ^ TRACE0 ("Failed to create toolbar\n") ; 

// return -1; // fail to create 

// } 

if ( ! m_wndStatusBar . Create ( this ) | | 

! m_wndStatusBar . Setlndicators ( indicators , 
sizeof (indicators) /sizeof (UINT) ) ) 

^ TRACE 0 ( "Failed to create status bar\n"); 
return -1; // fail. to create 

} 

// TODO: Delete these three lines if you don't want the toolbar to 

// be dockable 
/ / m_wndToolBar . EnableDocking ( CBRS_ALIGN_ANY) ; 
/ / EnableDocking ( CBRS_ALIGN_ANY) ; 
/ / DockControlBar ( &m_wndToolBar ) ; 

// Add Notify Icon. 
NOTIFYICONDATA nid; 

nid.cbSize = sizeof (NOTIFYICONDATA) ; 
m notifylconWnd = m_hWnd; 
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nid.hWnd = m_notifyIconWnd; 
nid.uID = 0; 

nid.uFlags = NIF_ICON | NIFJTIP | NIF_ MESSAGE ; 
nid.hlcon « Loadlcon (Af xGetlnstanceHandle ( ) , . 

MAKEINTRESOURCE(IDR_NOTIFYICON) ) ; 
nid.uCallbackMessage = WM_USER_NOTIFYICON; 

CString toolTip ("Pushcast Player"); 

LPCTSTR IpszToolTip = toolTip .GetBuf f er (toolTip . GetLength () ) ; 
lstrcpyn (nid. szTip, IpszToolTip, strlen (IpszToolTip) +1) ; 



Shell^NotifylcondTIM^ADD, &nid) ; 

// Setup autoDL timer to check every minute. 

Se tTitner ( 1 , 60000, DLTimerProc ) ; 

return 0; 

} 

BOOL CMainFrame: :PreCreateWindow(CREATESTRUCT& cs) 

^ if( I CFrameWnd: :PreCreateWindow(cs) ) 

return FALSE; 

// TODO: Modify the Window class or styles here by modifying 
// the CREATE S TRUCT cs 

/* Remove the Document Name from the Title Bar 

See "Programming Windows with MFC 2nd Ed." by Jeff Prosise 
p574-575 */ 

cs. style &= -FWS_ADDTOTITLE ; 

return TRUE; 

} 

ii/iiiiiiiiiiitiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiuiiiiiiiiiiiii 1111111 
inn 

II CMainFrame diagnostics 
#if def _DEBUG 

void CMainFrame: :AssertValid() const 

^ CFrameWnd : : Assert Valid ( ) ; 
} 

void CMainFrame: : Dump (CDumpContext& dc) const 

^ CFrameWnd: :Dump (dc) ; 

} 

#endif //_DEBUG 

///////////////////////////////////////////////////// /////////////////7/ 
///// 

// CMainFrame message handlers 
i 

BOOL CMainFrame: :OnCreateClient (LPCREATESTRUCT lpcs, 

CCreateContext* 

pContext) 
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// create a splitter with 3 row, 1 columns 
if ( !m_wndSplitterl . CreateStatic (this , 2,1)) 

^ TRACEO ("Failed to CreateStaticSplitter\n") ; 
return FALSE; 

} 

// add the first splitter pane - the default view in column 0 

// Add the Web View 

if (!m wndSplitterl.CreateViewd, 0, 

RUNTIMB_CLASS (CWebView) , CSize(0,0), pContext) ) 

^ TRACEO ("Failed to create CWebView\n") ; 

return FALSE; 

} 

// add the second splitter pane - which is a nested splitter with 

1 rows . 

■ if (!m wndSplitter2 . CreateStatic ( . . 

&m_wndSplitterl, // our parent window is the first 

splitter //the new splitter is 1 rows, 2 column 

WS.CHILD I WS_VIS1BLE | WS_BORDER, // style, WS.BORDER is 

needed _ . x 

m wndSplitterl.IdFroroRowCoKO, 0) 

- // new splitter is in the first row, 2nd column of 

first splitter 
)) 

^ TRACEO ("Failed to create nested splitter\n") ; 
return FALSE; 

} 

// now create the two views inside the nested splitter 

// Seate the List View first because it is needed by the tree 

view. . , _ - 

if (!m wndSplitter2.CreateVxew(0, 1, . ^ ^ 

R^lL.CLASStCDisplayView), CSize(0, 250), pContext)) 

^ TRACEO ("Failed to create third pane\n") ; 
return FALSE; 

if Cm wndSplitter2 - CreateView (0,0, 

RSOTIME^CLASS(CFoldersView), CSizedSO, 250), pContext)) 

^ TRACEO ("Failed to create second pane\n") ; 

return FALSE; 

} 

m_wndSplitterl . SetRowInf o (0,150,0); 

// it all worked, we now Have two splitter windows which contain 
// three different views 

// nove get references to them. 

//mj>layerView = reinterpretcast<CPlayerVxew *> 
(m wndSplitterl.GetPane (1, 0)); 

(m - m^displayView = reinterpret_cast<CDisplayVxew *> 
(m wndSplitter2.GetPane(0, 1) ) ; 

( " ^f oldersView = reinterpret_cast<CFoldersVxew *> 
(m_wndSplitter2 . GetPane ( 0 , 0 ) ) ; 
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m_webview = reinterpret^ cast<CWebView *> (m_wn.dSplitterl . GetPane 
(1,0)); 

return TRUE; 

} 

LRESULT CMainFrame: :OnMyUpdateMessage (UINT wParam, LONG lParam) 

^ GetPlayerDoc () ->UpdateAllViews (NULL) ; 

return 0; //I handled this message 

} 

LRESULT CMainFrame: :OnSetProgress (WPARAM wParam, LPARAM) { 
if (m_syncStatusDlg != NULL) { 

m_syncStatusDlg->m_progress_overall.SetPos ( (int) wParam) ; 

} 

return 0; 

} 

LRESULT CMainFrame : : OnNotif ylcon (WPARAM wParam, LPARAM lParam) 

^ CString toolTip ("Pushcast Player"); 

LPCTSTR IpszToolTip = toolTip . GetBuf f er ( toolTip. GetLength () ) ; 

UINT uID;" 
UINT uMouseMsg; 

uID = (UINT) wParam; 
uMouseMsg = (UINT) lParam; 

if (uMouseMsg == WM_LBUTTONDBLCLK) { 
switch (uID) { 
case 0: 

ShowWindow (SW_RESTORE) ; 

break; 
default : 

TRACE ( "Unhandled Task Tray Left Click. \n 11 ); 

break; 

if (uMouseMsg — WM_RBUTTONUP ) { 

TRACE ( "WM__RBUTTONUP from systray icon.\n tt ) ; 
switch (0) { 
case 0: 

TRACE ("Right Click On Task Tray.\n"); 
DoRightClickOnTraylconO ; 
break; 
default : 

TRACE( "Unhandled WMJSIOTIFY message. \n" ) ; 
break; 

if (uMouseMsg == WM_MOUSEMOVE) { 

switch (uID) { 

case IDIJsTOTIFYICON : 
/'/ char tip [64]; 

// char val[32] ; 
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/* 

Connected" ) ; 

Downloading\n ( " ) 
(),val,10); 

*/ 



// Modify tooltip to contain current status. 
NOTIFYICONDATA nid; 

nid.cbSize = sizeof (NOTIFYICONDATA) ; 
nid.hWnd = m_notifyIconWnd; 
nid.uID = IDI_NOTIFYICON; 
nid.uFlags « NIFJTIP; 

if (m_j>layerView->m_progressCtrl.GetPos 0 — 0) 
strcpy(tip, "Pushcast Player\nStatus : Not 

else 

strcpy(tip, "Pushcast Player\nStatus : 
itoa (mjplayerView->mj?rogressCtrl .GetPos 

s treat {tip, val) ; 

strcat (tip, "% complete) ") ; 

//strcpy(nid.szTip, tip) ; 

lstrcpyn (nid. szTip, IpszToolTip, strlen (IpszToolTip) +1) ; 

ShellJSrotifylconfNIMJVIODIFY^id) ; 

break; 



} 



default : 

break; 

} 



} 



return TRUE; 



void CMainFrame : : OnClose ( ) 

^ // TODO: Add your message handler code here and/or call default 

// Empty trash. 
GetPlayerDoc ( ) - >EmptyTrash ( ) ; 

// Stop the Download. 
GetPlayerDoc () ->StopDownload() ; 

// Delete the Status Window if* there .is one. 
DeleteStatusDlg ( ) ; 

// Delete the Media Window if one exists. 
DeleteMediaWindowO ; 

// Delete Notify Icon 
NOTIFYICONDATA nid; 
nid.hWnd = mjiotifylconWnd; 
nid.uID = IDI_NOTIFYICON; 
Shell_Notif ylcon (NIMJDELETE , &nid) ; 

CFrameWnd: : OnClose () ; 

} 

void CMainFrame : : DoRightClickOnTraylcon ( ) 
^ DWORD dwPos = GetMessagePos () ; 

/* Convert the co-ords into a CPoint structure */ 
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CPoint pt( GET_X_LPARAM ( dwPqs ), GET_Y_LPARAM ( dwPos ) ), spt; 
spt = pt; 

/* Convert to screen co-ords for hittesting */ 
//Ic.ScreenToClient ( &spt ); 

// Set rightClickPoint incase someone needs it in the future 
// for hittesting. 

//rightClickPoint = spt; 

// Add Popup menu 



CMenu menu; 

VERIFY (menu . LoadMenu ( IDR_T AS KTRAY_MENU ) ) ; 
CMenu* pPopup = menu.GetSubMenu(O) ; 
ASSERT (pPopup I = NULL) ; 
: : SetForegroundWindow (m_notif ylconWnd) ; 

P Popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON , pt.x, 
pt . y , Af xGe tMainWnd ( ) ) ; 

: :PostMessage(m_notifyIconWnd / WM_NDLL / 0, 0) ; 

} 

/ /void CMainPrame : : OnTaskTrayAbout ( ) 

//{ % 4 

// TRACE ( "About From Task Tray Message. \n n ) ; 

//} 

void CMainFrame : : OnUserLoadURL ( ) 

{ 

CWebView *webView; 

webView = reinterpret_cast<CWebView *> (m_wndSplitterl . Get Pane (1, 

0)); 

webView->go() ; 

} 

// Purpose: Show the. Download Status Dialog, 
void CMainFrame : : showStatus ( ) 

^ if (m_syncStatusDlg ~ NULL) { 

m_syncStatusDlg = new CSyncStatusDlg (NULL) ; 
m_syncStatusDlg->Create ( IDD_S YNCSTATUS , this) ; 
if (GetPlayerDoc ( ) - >IsDownloading ( ) ) { 

m_syncStatusDlg- >EnableCancelButton ( ) ; 



void CMainFrame: :SetupIconAnimat ion (DWORD dwMsgType,UINT nlndexOf Icon, 
CSt ring strToolTip) 

//Load the specified icon from the array 

HICON hlconAtlndex = AfxGetApp () ->LoadIcon (iconResourceArray 
[nlndexOf Icon] ) ; 

///Fill up the NOTIFYICONDATA Structure 
NOTIFYICONDATA iconData; 

iconData. cbSize » sizeof (NOTIFYICONDATA) ; 

iconData. hWnd = m_notifyIconWnd; //window's handle 
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™ = IDI NOTIFYICON ; //identifier 

iconData.uID mesSAGEINIF ICON|NIF_TIP; //flags 

iconData.uFlags = ™SVB. NOTIFYICON? //notification 

iconData . uCallbackMessage = WM_USER_noi 

^^IconData.hlcon = nlconAtlndex; //icon handle 

SzToo?Tip - strroolTip-OetBufferCstrToolTip.GetLength 
° > '" / /i s trcpyn(iconData. S zTip,lps Z ToolTip,strlen(lps 2 Tool T ip) + l) ; 

^^ell.NotifylcontdwMsgrype, & iconData) ; 

//Resources are precious ! 
if (nlconAtlndex) 

Destroylcon (hlconAtlndex) ? 

} 

void CMainFrarae: :CleanUpIconAnimation() 
{ 

LeSULT c^ir^'.^ityzcor^^ioost^^^m wParan,, LPARAM 

IParam) { 

int nlndexFirstlcon ■ 0; 

m iconAnimationCount =0; _. 0<KT _„ „u\ . 

SetupIconAnimation(NIM^MODIFy,nlndexFirstIcon, ) , 

m_iconAnitnationCount++ ; 

SetTimer (2,1000,NULL) ; 
return 0; 

Lou CMai^^P^otifyXcc^ticnCycleW^ vPara,,. »». 
IParam) { 

Se tupIconAnimation(NIM_MODIFY,m_iconAnitnationCount,«»); 

(NOM_ICONS_IN_DL_ANIMATION) ; 
return 0; 

L*» CMainFraBe.^tifyXcon^tionBndWABM .Par™, LPflRfiM 

IParam) { . 

TO _icoiiAnimatiOiiCount = 0/ 

NOTIFY I CONDATA nid; 

nidTcbSize = sizeof (NOTIFYICONDATA) ; 
tn notif ylcanWnd = mJiWnd; 
nld.hWnd = m_notifyIconWnd; 

Sid'.nIcof= L oadIcon(AfxGetInstanpeHandle() , 
MAKE INTRE S OURCE ( IDR_NOTIFYICON) ) ; 
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nid.uCallbackMessage = WM_USER_NOTIFYICON; 
strcpy(nid.szTip, _T("Pushcast Player")); 

KillTimer (2) ; 

Shell_NotifyIcon(NIM_MODIFY,&nid) ; 
return 0; 

} 

void CMainFrame : : OnTimer (UINT nlDEvent) 

1 // TODO: Add your message handler code here and/ or call default 

• SetupIconAnimat ion (NIM_MODIFY , mjlconAnimat ionCount , n " ) ; 
m_iconAnimationCount++ ; 

m_iconAnimationCount = m_iconAnimationCount% 
(NUM_ICONS_Hsr_DL_ANIMATION) ; 

CFrameWnd: : OnTimer (nlDEvent) ; 

} 

//////////////////////////////////////////// 
// Func t ions // 

// Purpose: Get the PlayerDocument 

// (eliminates the need to cast GetActiveDocument ( ) ) . 

CPlayerDoc* CMainFrame : : GetPlayerDoc ( ) 

return reinterpret_cast<CPlayerDoc*> (GetActiveDocument () ) ; 

. } 

// Purpose: Delete the Status Dilog if one exists, 
void CMainFrame: : Deletes tatusDlgO 

^ if (m_syncStatusDlg != NULL) { 

m_syncStatusDlg->DestroyWindow() ; 
delete m_syncStatusDlg; 
mjsyncStatusDlg = NULL; 

} . * 

} 

// Purpose: Delete the Media Window if one exists, 
void CMainFrame: :DeleteMediaWindow() 

^ // Delete the media dialog if there is one. 

if (m_nrviewer- != NULL) { 
/ / mjnviewer- >Des troyWindow ( ) ; 

m mviewer = NULL; 

} 

} 

//////////////////////////////////////////// ■ 

// Menu Handlers // 

// Purpose: Send a message to syncronizer to download new media 
// * when the ManulaReceive menu item is selected, 

void CMainFrame : : OnToolsReceive ( ) { 

showStatus ( ) ; 

StartDownloadO ; 

} 

IIIIIIUIIIIIIllllllllllllllllllllllllllHH 
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// Message Handlers // 

// Purpose: When the WM_JJSER_PLAY message is received, either create a 
// *" new media dialog and play the media or play the media 

// in the existing dialog, 

void CMainFrame : : OnPlay ( ) 

^ // Create a new Media Dialog if one is not created, 

if (mjnviewer == NULL) { 

CRuntimeClass* pRuntimeClass = RUNTIME_CLASS (CMediaFrame) ; 
m_mviewer = reinterpret_cast<CMediaFrame *> (pRuntimeClass -> 

CreateOb j ect ( ) ) ; . , 

// Set the Stats object in the Media Window object. 
m_mviewer->SetStats (GetPlayerDoc () ->GetStats () ) ; 

// else play the selected file, 
else { 

// Stop the currently playing file. 
rn_ ttrviewer->Stop () ; 

} 

// Play the currently selected file. 
.m_mviewer->SetActiveWindow() ; 

tnjrrviewer->Play (GetPlayerDoc 0 ->GetCurSelectedItem() ) ; 

} 

// Purpose: Message handler to delete the status object 
// ^ when it is closed. 

LRESULT CMainFrame: : OnDlDlgClose (WPARAM wParam, LPARAM) { 
DeleteStatusDlgO ; 

return 0; 

} 

// Purpose: Destroy the Media window and free the memory when it is 

closed. . 
LRESULT CMainFrame : : OnWMDlgClose (WPARAM wParam, LPARAM) { 
DeleteMediaWindow ( ) ; 

return 0; 

} 

void CMainFrame : : OnReceiveMessage ( ) 
{ 

m_elapsedMinutes++; 

if (m_elapsedMinutes > GetPlayerDoc () ->GetDLInterval () ) ( 
m_elapsedMinutes = 0; 
StartDownload ( ) ; 

TRACE ("Uped elapsed time by 1 minutes. \n" ) ; 

} 

// Purpose: Tell Document to stop downloading, 
void CMainFrame: :0nStopDownload() 

^ GetPlayerDoc ( ) - >S topDownload ( ) ; 

} 

// Purpose: Cleans up the thread when it is done downloading, 
void CMainFrame : : OnDoneDownload (WPARAM wParam, LPARAM IParam) { 
TRACE ( "DownloadThread exit code: %d\n", IParam) ; 



171 



WO 03/010634 PCT/US02/23713 



// Check the return code. 
CHardDriveFullDlg* hdFullDlg = NULL; 
switch (lParam) { 
case DT_D ISKS PACEERROR : 

// Show Error Dialog. 

hdFullDlg = new CHardDriveFullDlg () ; 

hdFullDlg- >DoModal () ; 

delete hdFullDlg; 

break; 
default : 

break; 

} 

// Gray out Cancel on Sync status and the un gray the menu item 
if (tnjsyncStatusDlg) { 

m_syncStatusDlg- >DisableCancelButton ( ) ; 

DeleteStatusDlgO ; 

GetPlayerDoc ( ) ->DownloadThreadCleanup () ; 



} 



void CMainFrame : : StartDownload ( ) 

^ GetPlayerDoc ( ) - >PurgeAndDownloadSubscriptions ( ) ; 
if (m_syncStatusDlg) { 

m syncStatusDlg- >EnableCancelButton ( ) ; 

» 1 " 



// Purpose: Show the Sync Status Dialog, 
void CMainFrame: : OnSyncStatus () 



showStatus ( ) ; 

} 
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// MainFrm.h : interface of the CMainFranie class 
// 

//////////////////////////////////////////////////////////////////////// 
///// 

#if !def ined (AFX MAINFRM H 51A27727 F808 _ 49B2_9438_25C12ECC3778 
INCLUDED ) 

#def ine AFX MAINFRM H 51A27727 F8 0 8_4 9B2_943 8_25C12ECC3 778 INCLUDED^ 

#if _MSC_VER > 1000 
#pragma once 

#endif // _MSC_VER > 1000 

#include "DisplayView.h" 

#include " Folders View.h" 

#include "WebView.h" 

#-include "MediaFrame . h" 

#def ine IDI_NOTIFYICON 0 

class CMainFrame : public CFrameWnd 

{ 

protected: // create from serialization only 
CMainFrame ( ) ; 

DECLARE_DYNCREATE (CMainFrame) 

// Operations 
public : 

// Overrides 

// ClassWizard generated virtual function overrides 
/ / { { AFX_V IRTUAIi ( CMainFrame ) 
public : 

virtual BOOL PreCreateWindow(CREATESTRUCT& cs) ; 
//}}AFX_VIRTDAL 

// Implementation 
public : 

void StartDownloadO ; 

int m_iconAnimationCount; 

CPlayerDoc* GetPlayerDoc () ; 

void CleanUpIconAnimationO ; 

void SetupIconAnimation (DWORD dvfl4sgType,UINT nlndexOf Icon, CString 
strToolTip) ; 

void showStatus ( ) ; 

virtual -CMainFrame ( ) ; 
#ifdef JDEBUG 

virtual void AssertValidO const; 

virtual void Dump(CDumpContext& dc) const; 

#endif 

protected: // control bar embedded members 
CStatusBar m_wndStatusBar ; 

CToolBar ra_wndToolBar ; 

CSplitterWnd m_wndSplitterl ; 

CSplitterWnd m_wndSplitter2 ; 

CFoldersView *m_f older s View; 

CDisplayView *m_displayView; 
CWebView *m webView; 
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// Generated message map functions 
protected: 

void DoRightClickOnTraylconO ; 

virtual BOOL OnCreateClient (LPCREATESTRUCT Ipcs, 

CCreateContext* pContext) ; 
// { {AFX_MSG (CMainFrame) 

afxjmsg int OnCreate (LPCREATESTRUCT IpCreateStruct) ; 
afx_msg LPARAM OnMyUpdateMessage (UINT wParam, LONG lParam) ; 
af x_rasg LRESULT OnSetProgress (WPARAM wParatn, LPARAM) ; 
afx_msg void OnReceiveMessage 0 ; 
af x_msg void OnSyncStatus ( ) ; 

afx_msg LRESULT OnNotif ylcon (WPARAM wParam, LPARAM lParam) ; 
afx_msg LRESULT OnNot if ylconAnimationS tart (WPARAM wParam, LPARAM 
1 Par am) ; 

afx_msg LRESULT OnNotif ylconAnimationCycle (WPARAM wParam, LPARAM 
lParam) ; 

afx_msg LRESULT OnNotif ylconAnimationEnd (WPARAM wParam, LPARAM 

lParam) ; 

af x_msg void OnClose ( ) ; 
afxjnsg void OnPlayO ; 
afxjmsg void OnUserLoadURL ( ) ; 

afx_msg LRESULT OnWMDlgClose (WPARAM wParam, LPARAM) ; 
afxjmsg LRESULT OnDlDlgClose (WPARAM wParam, LPARAM) ; 
afxjmsg void OnTimer(UINT nIDEvent) ; 
afx_msg void OnToolsReceive () ; 
afx_msg void OnStopDownload ( ) ; 

af x msg void OnDoneDownload (WPARAM wParam, LPARAM lParam) ; 

//}Jafx_msg 

declarejmessage_map() 
private : 

void DeleteMediaWindowO ; 

void DeleteStatusDlgO ; 
// CSyncThread *m_syncThread; 

CSyncStatusDlg* m_syncStatusDlg; 

CMediaFrame* m_mviewer; 

HWND m_notifyIconWnd; 

int m_elapsedMinutes; 

}; 

/////////////////////////////////////////////////////// //////////////7// 
///// 

//{{AFX INSERT_LOCATION} } . . 

// Microsoft Visual C++ will insert additional declaratxons lmmedxately 

before the previous line. 

#endif // !defined(AFX_MAINFRM_H_51A27727_F808_49B2_9438_25C12ECC3778 
INCLUDED ) 
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// MediaFrame.cpp : implementation file 
// 

#include "stdafx.h" 
#include "player. h" 
#include "MediaFrame.h" 

#if def _DEBUG 
#define new DEBUG_NEW 
#undef THIS_FILE 

static char THIS_FILE [] = _FILE__; 
#endif 

////// ui///unH///////ti/////unuu/u////ini/n//f/i///in/un// 
inn 

II CMediaFrame 

IMPLEMENTED YNCREATE (CMediaFrame, CFrameWnd) 

CMediaFrame : : CMediaFrame ( ) 

^ RECT r; 

r.left = 100; 
r.top = 100; 
r. right = 200; 
r. bottom = 200; 

// Create the Media Window. 
Create ( ^ SySM E^|wf WS.MINIMIZEBOXlWS.MAXIMIZEBOX, 
r, NULL, 0) ; 

NULL) mjap . SetSendPlayStateChangeEvent s (TRUE) ; 
m_mp . SetAutoSize (TRUE) ; 
ra mp.SetDisplaySize(O) ; 
irTmp . ShowWindpw ( SW_SHOW) ; 

} 

CMediaFrame : : -CMediaFrame ( ) 

s 

BEGIN EVENTS INK_MAP (CMediaFrame , CFrameWnd) 

OnEndOfStreamMediaplayerl, VTS_I4) 

/ / } } AFX_EVENTS INK_MAP 
END_EVENTS INK_MAP ( ) 

BEGIN MESSAGE_MAP (CMediaFrame, CFrameWnd) 

""""^B^'S* cSSSLard will add «a re^e mapping -acros 

here. «/x 

ON_WM_CLOSE() 
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ON_WM_SIZE() 
//}}AFXJ5SG_MAP 
END_MESSAGE_MAP ( ). 

//////////////////////////////////////////////////////////////////////// 
///// 

// CMediaPrame message handlers 

BOOL CMediaFrame: :PreCreateWindow(CREATESTRUCT& cs) 

// TODO: Add your specialized code here and/or call the base class 
return CFrameWnd : : PreCreateWindow ( cs ) ; 

} 

// Purpose: Handles the stats logging when control buttons axe pressed, 
void CMediaFrame: :OnPlayStateChangeMediaplayerl (long OldState, long 
NewState) 

// Play was pushed, 
if (NewState ==2) { 

// Player was paused, 
if (OldState ==1) { 
// m_stats->addStat (0, (LPCTSTR) m_mp. GetFileName () , 

I/ ^ 0, 0, mjmp.GetCurrentPosition 

() , "unpause") ; 

// Player was stopped, 
else { 

mjstats - >addStat ( 0 , (LPCTSTR) mjrap . GetFileName ( ) , 

0, o, mjmp.GetCurrentPosition 

X) , "start"); 
} } 

// Pause was pushed. 

else if (NewState »« 1) { 
/ / m_stats->addStat (0, (LPCTSTR) rajmp . GetFileName ( ) , 

II 0, 0, m_mp.GetCurrentPosition 

(), "pause"); 

// Stop was pushed. 

else if (NewState == 0) { 

/ / mjstats - >addStat ( 0 , (LPCTSTR) mjnp . GetFileName ( ) , 

II , 0, 0, m_ii5).GetCurrentPosition 

() , "stop"); 

} 

} 

// Purpose: This is called before the window is closed. 

// ^ Enables the Launch Media Button in the Player View. 

void CMediaFrame : :OnClose ( ) 

^ // Media was playing when the window was closed so 

// record a stop stat. 
long playState = m_mp . GetPlayState ( ) ; 
if (playState ==2) { 

■ m stats->addStat(0, (LPCTSTR) injnp . GetFileName ( ) , 

0,0, mjmp . GetCurrentPos it ion ( ) , 

"stop"); 
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// Enable the Launch Media Button in the Player View. 
// By sending the WM_USER_WMDLG_CLOSE message to the playerview. 
: :PostMessage(AfxGetMainWnd() - >m_hWnd , WMJUSER_Wl©LG_CLOSE , (WPARAM) 
0, (LPARAM)O) ; 

CFrameWnd: :OnClose () ; 

} 

// Purpose: Called whenever the position of the media is changed, 
void CMediaFrame: :OnPositionChangeMediaplayerl (double oldPosition, 
double newPosition) 

{ 

// When the new position is 0, 
if (newPosition == 0) { 

// stop has been pressed so log a stop stat. 

m_stats->addStat (0 , (LPCTSTR)m_mp.GetFileName () , 

0, 0, oldPosition, "stop"); 

, 1 

// Purpose: Resize the media dialog when the user resizes the dialog- 
void CMediaFrame: :OnSize (UINT nType, int cx, int cy) 

{ 

CFrameWnd : : OnSize (nType , cx , cy ) ; 

// Check for 'a valid media player object, 
if (m_mp) { 

// Resize the object to fit the window. 

m mp . MoveWindow ( 0 , 0 , cx, cy, TRUE) ; 

, 1 " 

void CMediaFrame: :OnEndOf StreamMediaplayerl (long Result) 

{ 

// The end has been reached so record a stop stat. 
m_stats->addStat (0, (LPCTSTR)m_mp.GetFileName () , 

0,0, mjmp . GetDuration ( ) , "stop") ; 

xmlNodePtr toSetToCurrent = NULL; 

if (curPlayingNode == NULL) {return;} 

if (curPlayingNode- >next == NULL) { return; } < 

bool playNext = false; 

if (curPlayingNode- >next != NULL) { 

if (curPlayingNode->next->type == XML_ELEMENT_NODE) { 
- toSetToCurrent = curPlayingNode ->next; 
playNext = true; 

} 

else { 

return; // there isn f t.even a next node 

} 

if (curPlayingNode- >next->next != NULL && playNext != true) { 

if ( curPlayingNode ->next->next-> type == XML_ELEMENT_NODE ) { 
toSetToCurrent = curPlayingNode ->next->next; 
playNext = true; 

} 

} 

if (playNext) { 
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curPlayingNode = toSetToCurrent ; 
Play(curPlayingNode) ; 

} 

} 

// Purpose: Initialize the Player with the selected media 
// " and start the media playing, 

void CMediaPrame : : Play (xmlNodePtr curltetnNode) { 

// Get the selected Document. 

curPlayingNode = curltemNode; 

// If a Document is selected, 
if (curPlayingNode != NULL) { 
// Get the filename. 

xmlChar *url = xmlGetProp (curPlayingNode, 

reinterpret_cast<const unsigned char *> 
("URL") ) ; 

xmlChar *show = xmlGet Prop (curPlayingNode, 

reinterpret^ cast<const unsigned char *> 
("SHOW")) ; 

xmlChar *desc = xmlGetProp (curPlayingNode, 

reinterpret_cast<const unsigned char *> 
("DESC")) ; 

xmlSetProp (curPlayingNode, f.^™™™.,* 
reinterpret_cast<const unsigned char *> ("LISTENED") , 
reinterpret_cast<const unsigned char *>("!")); 

string strURL * reinterpret_cast<const char *>(url); 
string strDESC = reinterpret_cast<const char *>(desc); 
string strSHOW = reinterpret_cast<const char *>(show); 
string strTITLE = StrSHOW + " - " + strDESC; 
// Open the media player with the file. 
m_mp . SetFileName (strURL . c_str ( ) ) ; 
// Set the window title to the description. 
SetWindowText (strTITLE . c_str () ) ; 

// Set the window Icon to the parent icon. This is a 
temporary f ^ tIcon(LoadIcon( ^ x ^ tInst ^ ceH ^ dle () , MAKE INTRE SOURCE 
( IDR_MAINFRAME ) ) , false) ; , 

// Resize dialog to size of media. 
CRect mediaRect; 
mjmp.GetWindowRect (mediaRect) ; 

CRect windowRect; 
GetWindowRect (windowRect) ; 

CRect clientRect; 
GetClientRect (clientRect) ; 

int deltaWidth = windowRect. Height 0 - clientRect .Height 0 ; 
int deltaHeight = windowRect. Height () - clientRect .Height () ; 

MoveWindow (windowRect . lef t , windowRect . top , deltaWidth + 
mediaRect. Width () , deltaHeight + mediaRect .Height ()) ; 
SHowWindow(SW_SHOW) ; 
UpdateWindow ( ) ; 

// Play the open the currently loaded media. 
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tn rap . PlayO ; 

} 

} 

// Purpose: Stop the currently playing media and sets the stat. 
void CMediaFrame : : Stop ( ) { 

// Stop media. 

m_mp.Stop() ; 

£42.53-SS(0. ^^^2™^sition(), "stop"); 

} 

// Purpose: Set the local Stats object to the passed in Stats object, 
void CMediaFrame::SetStats(CStats* s) { 
m_stats = s; 

} 
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